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PREFACE 



The purpose of this text is to provide a detailed 
reference source containing: 

1. a functional description of the Honeywell 
Series 200 Models 200, 1200, and 2200 
and their components. 

2. a definition of the Series 200 Assembly 
System (Easycoder). 

3. a detailed explanation of machine opera- 
tion codes. 

The only prerequisite for a thorough understanding of the 
information presented in this manual is a familiarity with 
basic data processing terminology. No previous knowledge 
of the Series 200 is assumed. 

The equipment characteristics reported herein re- 
main subject to change in order to allow the introduction 
of design improvements. 



The following publications are hereby superseded: 

Honeywell 200 Programmers' Reference Manual (DSI-214), 
Honeywell 2200 Programmers' Reference Manual (DSI-304), 
Easycoder 8K Assembly Language (DSI-409), and 
Easycoder 1 2K As sembly Language (DSI-313). 
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1 

SERIES 200 
COMPONENTS 



Honeywell's Series 200 Data Processing System is a set of modularly designed, compatible 
models, three of which — the Models 200, 1200, and 2200 — are the subject of this manual. 

Each model consists of two basic elements: a central processor, and an array of peripheral 
devices connected to that processor. The peripheral equipment in the system can be attached to 
any processor, and the number of connectable devices is limited only by the number of trunks 
available with any one processor. 

The initial member of Series 200 was the Model 200. The capabilities of the Model 200 
processor have twice been extended since its introduction. Thus, five central processors are 
described herein: the three processors of Model 200 (Types 201, 201-1, and 201-2); the Type 
1201; and the Type 2201. The processing power of any one of these types can be increased at 
anytime by the addition of peripheral devices and/or optional hardware features. This section 
describes: (1) the two basic elements of a Series 200 model (processor and peripheral devices); 

(2) the manner in which these elements communicate with one another; and (3) the expansion of 
processing power that is possible through the addition of optionalhardware featuresto aprocessor. 

CENTRAL PROCESSOR 

The central processor is the computing and 
control center of a Series 200 model; instruc- 
tions processed within the central processor 
control the operations of the entire computer. 

A Series 200 processor is functionally divided 
into three units: storage, control, and arithme- 

tic. The storage unit provides magnetic core 
storage for both the program instructions and 
the data to be processed according to these in- 
structions; it is also used to contain the resultant 
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data. The control unit directs the operation of the entire computer by selecting, interpreting, 
and controlling the execution of all program instructions. It controls not only the flow of infor- 
mation within the central processor but also the flow of data between the central processor and 
all peripheral equipment. The arithmetic unit performs such operations as addition, subtraction, 
multiplication, division, and comparison, as directed by the control unit. 

Included as a part of the central processor is a control panel (see Figure 1-1) which pro- 
vides for easy communication between an operator and the computer. By using various control 
switches, the operator can start and stop the machine and can load and interrogate memory lo- 
cations. The control panel also includes from four to eight SENSE switches which may be used 
in conjunction with programmed instructions to stop processing or to select predetermined pro- 
gram paths. The use of these switches increases the flexibility of a program, allowing it to be 
used in several different applications. 
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Figure 1-1. Type 1201 Control Panel 



Another communication medium between the operator and the central processor is the 
Type 220 console, of which three versions are available. The Type 220-1 console (Figure 1-2) 
contains a typewriter which may be used as a peripheral device, operating under program control, 
or as a logging typewriter by which the operator can make essential notes about the program in 
progress. The central processor control panel remains situated on the processor cabinetry and 
is used for the functions described above. 

In the Type 220-2 and Type 220-3 consoles (Figure 1-3), most of the control panel functions, 
including that of direct access to the processor, are performed by means of the console type- 
writer. In addition, the typewriter can perform the peripheral and logging functions described 
for the Type 220-1. The central processor control panel is replaced by a smaller control panel 
containing only the main power switches, the SENSE switches, and certain check condition 
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Figure 1-2. Type 220-1 Console Figure 1-3. Type 220-2 Console 

STANDARD PROCESSING MODE 

The central processor performs arithmetic and logical operations as directed by the in- 
structions of an internally stored program. These instructions are read into memory from an 
input medium such as punched cards, magnetic tape, or punched paper tape. Control circuitry 
within the processor then selects, interprets, and executes these instructions. Normally, the 
instructions are executed sequentially. Branch instructions are provided, however, which make 
it possible to skip over a group of instructions or otherwise change the sequence of the program. 

INTERRUPT PROCESSING MODE 

Sequential instruction execution is changed temporarily when the processor is interrupted. 
Any one of four sources (see below) can "demand" access to the central processor by generating 
an interrupt signal; this signal turns on a central processor interrupt indicator. An automatic 
hardware response is made to this condition; information concerning the current status of the 
processor is stored, and a branch is made to a stored routine which identifies and services the 
demand. Thus, programmed tests need not be made to detect the presence of an interrupt con- 
dition — the entire process of detecting and responding to an interruption is automatic. When 
the stored service routine has been executed, control is returned to the main program at the 
point where the interruption occurred. 
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The four sources of processor interruption are: 

1. Peripheral Control — The control connected to any Series 200 peripheral 
device can generate an interrupt signal under program control (peripheral 
controls are described on page 1-6). For instance, a data communication 
control which services one or a number of communication lines and de- 
vices may generate a real time demand on central processor time to handle 
a customer inquiry from a remote terminal. The current operations of the 
processor are temporarily interrupted so that the inquiry may be serviced. 
A routine to read the inquiry and to answer the question from a stored 
customer file is automatically executed, and a response is sent back to 

the terminal. 

2. Operator's Control Panel or Console — The operator can interrupt the 
central processor by pressing the INTERRUPT button on the control panel 
or console. The source of such "on-site" interruptions is made available 
to the program by the execution of a single instruction at the beginning of 
the interrupt service routine. 

3. Program Instruction — One instruction in the Series 200 repertoire, the 
Monitor Call instruction, is used to generate an interrupt condition. ^ 

For programming convenience, the activation (or "calling") of the monitor 
program can be accomplished by means of this instruction. 

4. Storage Protect Violation — The above-mentioned sources cause an ex- 
ternal interrupt condition. When a processor contains the Storage PTotect 
Feature (Types 1201 and 2201 only), an internal interrupt condition, caused 
by certain "violations" to storage protection, can also occur. Internal 
interruptions are of lower priority than external interruptions, so that a 
processor executing an external interrupt service routine cannot be 
interrupted by an internal interruption until the routine is completed. The 
nature of storage protect violations is described in Appendix E. 



PROCESSING POWER 

The power of any processor within Series 200 can be defined as the sum of its main 
memory size, its internal speed , its degree of peripheral simultaneity, and the number of 
optional features which may be added to it. 



Main memory size within the Models 200/1200/2200 ranges from a minimum of 2, 048 
character locations (Types 201 and 201-1) to 262, 144 locations (Type 2201). Figure 1-4 shows 
the modular main memory structures of the five processor types. 

The internal speed of a processor is measured in terms of a memory cycle (i. e. , the time 
required to read and restore the contents of a single character location). These speeds range 
from two microseconds to one microsecond for the five processors (see Figure 1-5). 



The Types 201 and 201-1 processors cannot be interrupted by sources 2. and 3. above. 
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CENTRAL PROCESSOR 



Peripheral simultaneity is a key feature of Series 200 processors. Among the processors 
described in this manual, from three (Model 200 processors) to eight (Type 2201 processor) 
simultaneous input /output operations can be performed concurrently with internal computing (see 
Figure 1 -6). 

A number of optional features can be included in the Series 200 processors to provide 
complete flexibility in specializing any one processor to a user's particular application. Since 
some of these features refer to the peripheral capabilities of a processor, they are summarized 
at the conclusion of this section. 
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Figure 1-4. Main Memory Size 



Figure 1-6. Peripheral Simultaneity 
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PERIPHERAL EQUIPMENT 

The array of peripheral devices available 
with Series 200 processors includes over 40 
units: punched card equipment, high-speed 
printers, magnetic tape units, paper tape equip- 
ment, magnetic tape strip mass memory units, 
random access drum units, and various data 
communication equipment. Also included are 
computer -to -computer adapters, an interval 
timer, a time of day clock, MICR reader / sorter 
controls, and magnetic tape switching units which provide extremely flexible Series 200 configu- 
rations . 

Information is transferred between any one of these devices and the central processor by 
means of a single stored-program instruction — the Peripheral Data Transfer instruction de- 
scribed in Section 8. By coding various control characters in this instruction, the programmer 
specifies the direction of data transfer (into or out of the processor), the specific device involved 
in the transfer, the data path over which information is to be transferred, and any other infor- 
mation necessary to define the input/output operation (e.g. , the number of lines to be spaced 
during printer operations). The actual communication with the central processor is not made by 
the particular peripheral device but by the peripheral control connected to that device. 

PERIPHERAL CONTROL 

A peripheral control regulates the transfer of data between a processor and a peripheral 
device. The control compensates for the difference in the data transfer rates of the processor 
and the peripheral device by temporarily storing each character of transmitted information until 
either the processor or the device is ready to receive the character. The control also converts 
each character into the code used by the intended recipient (e. g. , the card reader control con- 
verts a character from Hollerith code to the internal six-bit code of the central processor). As 
each character is transferred to the control, it is also checked for accuracy by the control. One 
particularly significant feature of the peripheral control is that it operates independently of the 
central processor and requires access to the main memory only when information transfe;rs are 
performed. In particular, all of the previously mentioned activities of the control — temporarily 
storing, converting, and checking the information — do not involve the central processor in any 
way. When each character of information is transferred, one main memory cycle is allocated 
for the transfer. 
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Some peripheral devices require one peripheral control per device (e.g. , a card reader). 
Other devices can be connected in multiple fashion to a single peripheral control (e. g. , up to 
eight 1 /2-inch magnetic tape units can be directed by a single control). The number of Series 
200 devices connectable to a peripheral control is shown in the following tables. 



PUNCHED CARD EQUIPMENT 

Series 200 includes a wide variety of peripheral devices not only of different kinds but also 
on several performance levels for the same kind. For instance, six different punched card units 
are offered: a card reader, a card punch, and four reader /punche s. Table 1-1 lists the card 

devices available within Series 200. Note that a card device requires either one or two "I/O 
trunks," depending on the number of functions the device performs. The significance of the 
I/O trunk is explained on page 1-13. 

Table 1-1. Series 200 Punched Card Equipment 



Device 






No. I/O Trunks 
Required by 
Control 


Type 




. Data Transfer Rate 


223 


Card Reader 




1 


1 


214-1 


Card Punch 




1 


1 


224-1 


Card Reader/Punch 


Read: 300 cards/ minute 

Punch: 50-270 cards/minute 


1 


2 


224-2 


Card Reader/Punch 


Read: 400 cards/ minute 

Punch: 90-360 cards/minute 


1 


2 


214-2 


Card Reader/Punch 




1 


2 


227 


Card Reader/ Punch 




1 


2 



HIGH-SPEED PRINTERS 

Five types of printers (see Table 1-2) produce printed reports, listings, etc., at speeds 
which vary from 450 to 1, 300 lines per minute. Processed information is printed from any pro- 
grammer-assigned area in memory. A single program instruction — the Move Characters and 
Edit instruction — allows the programmer to punctuate the output data, suppress zeros, and in- 
sert identifying symbols in the data prior to printing. 
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Table 1-2. Series 200 High-Speed Printers 





Data Tyaitsfer Rate 


No. Printers 
Per Control 


No. I/O Trunks 
Required by 
Control 


222-1 (96 print positions) 


650-1, 300 lines /minute 


1 


1 


222-2 (108 print positions) 


650-1, 300 lines /minute 


1 


1 


222-3 (120 or 132 print positions) 


650-1, 300 lines /minute 


1 


1 


222-4 (120 or 132 print positions) 


950-1,266 lines/minute 


1 


1 


222-5 (120 print positions) 


450 lines /minute 


1 


1 



MAGNETIC TAPE UNITS 

Magnetic tape is a compact and highly versatile medium for the storage of programs and 
data files. Two complete families of industry-acclaimed tape units are available with Series 200 
processors (see Table 1-3): 1 /2-inch tape xmits (10 types) transfer data at speeds ranging from 
7, 200 to 83, 300 characters per second; three types of 3 /4-inch, tape units read/write from 
32, 000 to 88, 800 characters per second. 



Table 1-3. Series 200 Magnetic Tape Units 







No* Devices 
Per Control 


Required by 
Control 


1 1 /2-Inch Magnetic Tape Units 


204B-1 

204B-2 


7, 200/20, 000 characters /second 


1-8 


2 


204B-3 

204B-4 


16, 000/44,400 characters /second 


1-8 


2 


204B-5 


24, 000/66, 700 characters /second 


1-8 


2 


204B-6 


30, 000/83, 300 characters/second 


1-8 


2 


204B-7 


7, 200/20, 000/28, 800 characters/ 
second 


1-8 


2 


204B-8 


16, 000/44, 400/64, 000 characters/ 
second 


1-8 


2 


204B-11 

204B-12 


13,300 characters /second 


1-4 


2 




204A-1 


32, 000 characters /second 


1-4 


2 


204A-2 


64, 000 characters /second 


1-4 


2 


2 04 A- 3 


88, 800 characters /second 


1-4 


2 
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MASS MEMORY FILE 

Honeywell's reputation for reliable magnetic tape control is inherited by the new member 
of Series 200, the Mass Memory File. Three types of transports, varying in access time and 
capacity, use magnetic tape strips to store programs and data files and thereby complement the 
main memory storage capacities of the central processor (see Table 1-4). A single control can 
provide access to over two billion characters of stored information. Data transfer rate is 
100, 000 characters per second, and average access times are as low as 95 milliseconds. 



Table 1-4. Series 200 Mass Memory File Units 





Device 




No; Devices 
Per Control 


No. I/O Trunks 
Required by 


Type 


Function 


Data Transfer Rate 




Control 


251 


Magnetic Tape Strip Transport 
(15 million characters) 


100, 000 characters /second 


1-8 


2 


252 


Magnetic Tape Strip Transport 
(60 million characters) 


100,000 characters /second 


1-8 


2 


253 


Magnetic Tape Strip Transport 
(300 million characters) 


100,000 character s /second 


1 -8 


2 



RANDOM ACCESS DRUM FILE 

The Series 200 drum file features a control unit which can direct from one to eight mag- 
netic drums, each capable of storing over two million characters of information (see Table 1-5). 
Thus, a single drum file subsystem can have a total capacity of over 20 million characters. Any 
record stored on the drum can be accessed in 27. 5 milliseconds (average) and can be transferred 
at the rate of 102, 000 characters per second. 



Table 1-5. Series 200 Magnetic Drum File Units 







No. Devices 
Per Control 


No. I/O Trunks 
Control 


Type 




270-1 

through 

270-8 


Magnetic Drum (2. 6 
million characters) 


102,000 character s /second 


1-8 


2 



PAPER TAPE EQUIPMENT 

Paper tape is an ideal medium for recording data which originates at locations distant 
from a central Series 200 installation and, as such, becomes particularly significant in data 
communication networks. A variety of standard commercial codes may be used with this rela- 
tively inexpensive medium. Two paper tape devices are offered in Series 200 (see Table 1-6). 
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Table 1-6. Series 200 Paper Tape Equipment 









No. I/O Trunks 
Required by 




.. r' ^ ^ ; ' 1 

;; i -i 


Data Transfe 


irCr L^oixtrox 


209 


Paper Tape Reader 


600 characters /second 


1 


1 


210 


Paper Tape Punch 


120 characters /second 


1 


1 



DATA COMMUNICATION EQUIPMENT 

The immediate and automatic response to an external interrupt source by the Series 200 
processor was described previously (page 1-3). A common source o£ external interruption is 
the communication control, of which two different types are available in Series 200. These 
controls allow the Series 200 processor to communicate with distant locations (e.g., branch 
offices, warehouses, etc. ) by receiving and transmitting data over toll and leased lines. Both 
single -channel and multi-channel data communication controls are offered; these controds adapt 
themselves to a broad selection of lines, speeds, and terminal devices. One such terminal 
device is Honeywell's Data Station (see Table 1-7). 



Table 1-7. Series 200 Data Communication Equipment 



laiilttii 




No* Devices 
Per Control 


No, I/O Trunks 
Required by 


Type 




Data Transfer Rate 






Communication Controls 






281 


Single -Channel Control 


Up to 5, 100 characters /second 


1 line 


2 


286 


Multi-Channel Control 


Up to 300 characters/second/ 
line 


1-63 lines 


2 






Remote Terminal Devioe 






288-1 


Datci Station Central 
Control 


120 characters /second 


n/a 


n/ a 


288-2 


Data Station Central 
Control & Keyboard 


120 characters/second 


n/a 


n/a 


289-2 


Data Station Page 
Printer & Keyboard 


10 characters /second 


n/ a 


n/a 


289-2A 


Keyboard 


10 characters/ second 


n/a 


n/a 


289-3 


Data Station Page 
Printer & Keyboard 


40 characters/ second 


n/ a 


n/ a 


289-4 


Data Station Paper Tape 
Reader 


120 characters/second 


n/ a 


n/ a 


289-5 


Data Station Paper Tape 
Punch 


120 characters/ second 


n/ a 


n/ a 
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Table 1-7 (cont). Series 200 Data Conamunication Equipment 



■ 




No. Devices 
Per Control 


No, I/O Trunks 
Required by 
Control 


Type 


:;|f 






Remote Terminal Device 


289-7 


Data Station Card 
Reader 


120 characters/second 


n/a 


n/a 


289-8 


Data Station Optical 
Bar Code Reader 


50 characters /second 


n/a 


n/a 



A major requirement of many communication networks (e, g. , inquiry handling or message 
switching applications) is fast access to a stored file. Files may sometimes be stored in main 
memory, but for large files main memory storage is economically unfeasible. File storage 
units (i.e. , the Mass Memory File, magnetic tape units, or drum file units) provide the answer 
to such mass storage applications. 

A typical data communication network is shown in Figure 1-7. The pertinent components 
of this system are: (1) a Type 201-2 processor; (2) a Type 251 Mass Memory File transport; 

(3) a Type 281 communication control; (4) two DATA-PHONE data sets^; and (5) a Honeywell 
Data Station, the remote terminal device. Two particular devices connected to the Data Station 
are used in this example: a keyboard by which the inquiry is transmitted to the central proc- 
essor, and a page printer which prints the answer to the inquiry in readable form. 

PERIPHERAL DATA TRANSFER OPERATION 

One of the major features of Series 200 is the degree of peripheral simultaneity that can 
be achieved by the various processors. The Model 200 processors (Types 201, 201-1, and 
201-2) and the Type 1201 processor can perform up to four peripheral operations simultaneously; 
the Type 2201 processor performs as many as eight simultaneous peripheral operations. While 
all these operations are being executed, the central processor continues its internal processing. 
The ability to perform simultaneous peripheral operations derives from an internal unit of the 
central processor, the input/output traffic control, which guarantees a peripheral control access 
to main memory when data is to be transferred. The manner in which the traffic control does 
this is explained in Section 2. The data path used by the traffic control to transfer data is de- 
scribed below; Figure 1-8 illustrates the basic elements which form this data path. 



^ A data set is required to convert the data signals used by the communication control to signals 
acceptable for transmission over communication lines. 
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1. Customer inquiry is typed on keyboard in 
form of a coded message. 



2. Message signals are converted to a form 
acceptable for transmission line. 

3. Message is transmitted over transmission 
line. 



4. Message signals are reconverted. 



5. Control generates interrupt signal and tranS' 
fers incoming message to pre-assigned 
memory location as directed by interrupt 
service routine. 



6. Stored interrupt service routine interprets 
message and issues instructions to read and 
update the customer's record in a file stored 
in Type 251 Mass Memory File transport. 



7. Type 250 control directs the execution of the 
instructions issued by the stored interrupt 
program. 



Customer's record is read and updated ac- 
cording to instructions. Record is read into 
pre-assigned location in interrupt routine 
(in central processor memory), from v/^hich 
the answer to the inquiry is sent back to the 
Data Station. (Answer to inquiry is printed 
l^y page printer. ) 



Figure 1-7. Customer Inquiry Handling via Typical Communications Network 
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CENTRAL PROCESSOR 




Figure 1-8. Basic Input/Output Data Path 



Input /Output Trunk 

An input/output trunk permanently connects a peripheral control (and its associated device) 
to the peripheral interface. The trunk transfers data either to or from the central processor 
and is therefore either an input or an output trunk, depending on the type of device it connects to 
the peripheral interface. For example, the I/O trunk connecting the card reader and its associ- 
ated control is an input trunk, while the I/O trunk connecting the printer and its control is an 
output trunk. A peripheral control which performs both input and output functions (e.g. , a mag- 
netic tape control) requires two I/O trunks: one for input operations, and one for output operations. 

The maximum number of peripheral controls that can be connected to a Series 200 processor 
is determined by the number of I/O trunks associated with that processor. For example, the 
Type 2201 can contain up to 32 I/O trunks, which means that as many as 32 peripheral controls 
Ccin be attached to the processor at one time (see Figure 1-10). 

Read/Write Channel 

Notice that the data path shown in Figure 1-8 is incomplete: there is no connection across 
the peripheral interface. This final link in the data path, known as a "read/write channel, " is 
inserted when the instruction is executed. Unlike an I/O trixnk, which is permanently connected 
to a peripheral control, the read/write channel is assigned by the programmer to specialize the 
data path between a peripheral control and the processor. 
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When the programmer codes a Peripherad Data Transfer instruction, he specifies among 
other things the peripheral control that is to send or receive the data (and therefore the I/O 
trunk connected to that control) and the read/write channel over which the data transfer is to take 
place. When the instruction is executed, the specified read/write channel is automatically in- 
serted in the peripheral interface. For example. Figure 1-9 shows the data path formed during 
the execution of a Peripheral Data Transfer instruction in which the programmer specifies that 
the card reader control is to transfer data over read/write channel 2 (RWC2). The specified 
channel remains in the interface only for the duration of the card read operation. When the data 
transfer terminates, RWC2 is automatically removed from the interface and is available for 
reassignment by another instruction. 




Figure 1-9. Data Path During Card Read Operation 



Read/write channels are the key to the achievable simultaneity in a Series 200 model: the 
number of read/write channels associated with a particular processor indicates the number of 
peripheral operations that can be performed simultaneously by that processor (see Figure 1--10). 



MODEL 



READ/WRITE CHANNELS 
(NUMBER OF SIMULTANEOUS 
OPERATIONS POSSIBLE) 



INPUT/OUTPUT TRUNKS 
(NUMBER OF PERIPHERAL 
CONTROLS POSSIBLE) 




BASIC 



OPTIONAL [ 



]32 



Figure 1-10. Data Path Components of Series 200 Processors 
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OPTIONAL FEATURES 

Table 1-8 lists the various features that can be added to the Series 200 processors de- 
scribed in this manual. This table illustrates the realistic design principle of Series 200: a 

Series 200 model can be specialized to meet the individual user's application; the application 
is not compromised to meet the design of the model. 

Certain features optional with some processors are standard with other larger types. 
This is also part of the realistic approach to system development. Particularly significant is 
the fact that specialization of a Series 200 model can occur at any time (not just at installation 
time) to meet any increased workload or applications shift that might occur. 

A summary description of the optional features is given below. 



Table 1-8. Series 200 Optional Features 



1 FEATURE 


201 


201-1 


201-2 


1201 


2201 


010 


ADVANCED PROGRAMMING 


n/ a 


n/a 


OPT 






on 


ADVANCED PROGRAMMING 


OPT 


OPT 


n/a 


n/a 


n/a 


012 


PROGRAM INTERRUPT 


OPT 










013 


EDIT INSTRUCTION 




OPT 


OPT 






015 


8 ADDITIONAL I/O TRUNKS 


OPT 


OPT 


OPT 






016 


AUXILIARY READ /WRITE CHANNEL 


OPT 


OPT 


OPT 




llM 


1100 


SCIENTIFIC UNIT 


n/a 


n/a 


n/a 


OPT 


OPT 


1115 


16 ADDITIONAL I/O TRUNKS & 4 ADDITIONAL RWC'S 


n/ a 


n/ a 


n/a 


n/ a 


OPT 


1114 


STORAGE PROTECT 


n/a 


n/a 


n/a 


OPT 


n/a 


1117 


STORAGE PROTECT 


n/a 


n/a 


n/a 


n/a 


OPT 



STANDARD 



OPT 



OPTIONAL 



ADVANCED PROGRAMMING 

Two Advanced Programming Features increase the basic instruction repertoire of the 
Model 200 processors. Feature 011 is available with the Types 201 and 201-1 processors, and 
feature 010 can be added to the Type 201-2 processor. Each feature includes the following 
capabilities (see Table 1-9): 

1. Additional program instructions. 

2. The ability to modify instruction addresses via indexed or indirect ad- 
dressing (described in Section 4). 

3. A "read reverse" capability with magnetic tape units. 
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Table 1-9. Model 200 Advanced Programming Feature 



FEAT URE 0 1 0 {Type 201 - 2 ) 




Program Instructions 


Program Instructions 


1 . Zero and Add 


1 . Zero and Add 


2. Zero and Subtract 


2. Zero and Subtract 


3. Branch if Character Equal 


3. Branch if Character Equal 


4. Change Sequencing Mode 


4. Change Sequencing Mode 


5. Extended Move 


5. Change Addressing Model 


6. Move and Translate 


6. Extended Move 


7. Branch on Character Condition (expanded 


7. Move and Translate 


version) 


8. Branch on Character Condition (ex- 


8. Branch on Bit Equal 2' 


panded version) 




9. Load Control Registers^ 


Address Modification 


Address Modification 


1. Indexed addressing via 6 or 15 index 


1. Indexed addressing via 6 or 15 index 


registers^ 


registers 


2. Indirect addressing 


2. Indirect addressing 


Read Reverse 


Read Reverse 



Any Model 200 processor can read 1 /2-inch magnetic tapes in a reverse direction and transfer 
the information to the main memory in the normal (forward) direction. 



The Change Addressing Mode instruction is available in Type 201 or 201-1 processors which 
include either the Advanced Programming Feature or a main memory capacity greater than 
4, 096 characters. It is included in the standard instruction repertoire of the Type 201-2 
processor. 

'The Branch on Bit Equal instruction is optionally available only with the Type 201-2 processor. 
The Load Control Registers instruction, optional with the Types 201 and 201-1 processors, is 
included in the standard instruction repertoire of the Type 201-2 processor. 

The Types 201-1 and 201-2 processors with the Advanced Programming Feature contain 6 in- 
dex registers in the three -character addressing mode and 15 index registers in the four-char- 
acter mode. The Type 201 processor with the Advanced Programming Feature contains six 
index registers, regardless of addressing mode. 



PROGRAM INTERRUPT 

This feature, whose basic functions are described on page 1-3, is an optional feature for 
the Type 201 processor and is standard for all other processors described herein. A detailed 
description of program interruption, including conditions which, must be present for an interrupt 
to occur, processor activities which are automatically performed when the interrupt takes place, 
and the programming of interrupt service routines, is given in Appendix D. 



EDIT INSTRUCTION 

A comprehensive instruction — Move Characters and Edit — is optionally available with 
the Model 200 processors and is a standard feature with the Types 1201 and 2201 processors. 
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Processed information is edited before being converted to an output medium (e.g. , a printed 
document) by the suppression of unwanted characters and symbols and the insertion of identi- 
fying symbols such as the dollar sign, decimal point, and asterisk. The Move Characters and 
Edit instruction is described on page 8-102. 

ADDITIONAL INPUT /OUTPUT TRUNKS AND READ/WRITE CHANNELS 

Any information transferred between the central processor and a peripheral device is 
transmitted over a "data path" formed by a read/write channel and an input /output trunk. (The 
significance of these two elements is described on page 1-13. ) The degree of peripheral simul- 
taneity achievable by a processor and the number of peripheral devices connectable to that 
processor depends on the number of read/write channels and input/output trunks available, 
respectively. Three optional features allow a user to increase his processor's peripheral 
flexibility by adding the following elements: 

1. Feature 015 — Eight additional input /output trunks for a Model 200 

processor. 

2. Feature 016 — One additional (auxiliary) read/write channel for a Model 

200 processor. 

3. F eature 1115 — Four additional read/write channels and 16 additional 

input /output trunks for the Type 2201 processor. 

The input /output trunks of Feature 1115 can be used 
only in conjunction with the read/write channels of 
this feature. 



SCIENTIFIC UNIT 

The scientific unit, which is physically contained in a separate unit of Series 200 cabinetry, 
adds 14 scientifically oriented instructions to the Series 200 repertoire. Available with the 
Types 1201 and 2201 processors, it is summarized in Appendix F and described in detail in the 
Honeywell Information Bulletin entitled Scientific Unit fo r Model 1200 and 2200 (Feature 1100). 

STORAGE PROTECT 

Two Storage Protect Features, identical in nature, are offered to the Type 1201 and 2201 
processors as Features 1114 and 1117, respectively. These features allow a programmer- 
specified portion of the main memory (and the contents thereof) to be shielded from accidental 
alteration by programs running concurrently in the memory. Any attempt to violate the pro- 
tection of this area results in an "internal" processor interruption. The program or programs 
running in the protected memory area have 15 additional index registers at their disposal; these 
registers can also be used by programs in the unprotected (or "open") memory area if desired. 
The Storage Protect Feature is described in Appendix E. 
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2 

THE CENTRAL 
PROCESSOR 



A Series 200 central processor is logically divided into five basic units (see Figure 2-1): 
a main memory, a control memory, an arithmetic unit, a control unit, and an input/output 
traffic control. 




Figure 2-1. Logical Division of Series 200 Central Processor 



MAIN MEMORY 

The main memory contains from 2, 048 to 262, 144 character locations of magnetic core 
storage which are used to store program instructions and data during a program run (see 
Figure 2-2). 

Nine planes of cores (see Figure 2-3) are placed on top of one another to form a memory 
"stack"; nine cores aligned vertically form a character position in memory. Every character 
position is identified by a unique numeric address. This means that an instruction can designate 
the exact storage locations that contain the data neededfor a particular operation. 
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Figure 2-2. Main Memory Functions 




Figure 2-3. A Main Memory Core Plane 



Figure 2-4 shows one character position of memory with the name of each core shown to the 
right. Each core can be individually magnetized to represent either a one or a zero, depending 
upon its polarity. Moving from bottom to top in Figure 2-4, the first six cores are used for data 
storage, the seventh and eighth cores are used to define the limits of storage areas (these two 
cores are frequently referred to as "punctuation" bits), and the ninth core is used for parity 
checking. 

Figure 2-5 shows how typical numeric, alphabetic, and special characters are stored in the 
main memory. Shaded circles represent cores containing 1-bits. Bits 1, 2, 4, and 8 in each 
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MAIN MEMORY 



character position can be combined to represent the decimal values zero through nine. This 
four-bit representation of decimal numbers is known as binary coded decimal (BCD). Alphabetic 
and special characters are represented by a combination of numeric (1, 2, 4, and 8) and the A 
and B cores. The A and B cores correspond to card zone punches: the A bit represents a 12- 
punch, the B bit represents an 11 -punch, a combination of the A and B bits represent a 0-punch. 
A listing of the main memory formats for all valid Series 200 characters appears in Appendix B. 



CORE 


FUNCTION 


© 


PARITY BIT (P) 


© 


ITEM MARK BIT (IM) 'k 

\ PUNCTUATION BITS 


© 


WORD MARK BIT (WM) } 


© 


B BIT ) 

[> ZONE BITS 




A BIT i 




8 BIT 




4 BIT 




2 BIT 


191 


1 BIT 





CHARACTER 


0 


4 


9 


B 


M 




{ 


F 




P 


( ) 


o 


o 


"o' 


o 
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IM 
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0 
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1 
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U 
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o 


o 



Figure 2-4. One Memory Position Figure 2-5. Representation of Characters 

in Magnetic Core Storage 

The word-mark bit (WM) is used to define storage fields in the memory. Information is 
rarely stored in the memory as single, independent characters; instead, adjacent character 
positions are usually grouped to form storage fields. As described in Section 3, the word-mark 
bit is instrumental in defining the size of such fields. 

Consecutive storage fields are frequently grouped together to form a unit of information 
called an item. As its name implies, the item-mark bit (IM) is used to define the size of an item 
in the main memory (see Section 3). 

A unit of information that is to be transferred between the main memory and a peripheral 
device is called a record. A record can be of any length, from one character up to virtually the 
maximum number of characters in the memory. Both the word-mark and item-mark bits are 
used in defining the size of a record (see Section 3). 

The parity bit (P) is used in conjunction with an automatic error-detection technique known 
as parity checking. Every character must be represented in the central processor by an odd 
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number of one -bits. Whenever a character is moved from one location to another it is automati- 
cally checked to determine if an odd number of bits has been moved. In Figure 2-5, the charac- 
ters 0, 9, B, M, and ( are represented by an even number of information bits. Circuitry within 
the central processor automatically adds a one in the parity bit positions of these characters to 
provide the required odd bit count. 



CONTROL MEMORY 

The control memory is a magnetic core storage unit consisting of up to 37 individually 
addressable control registers. ^ (The number of registers actually available depends on the 
system configuration. ) Normally, control registers contain the addresses of instructions and of 
the data being processed during a program run. One such register, called the A-address 
register, is illustrated in Figure 2-6. In this example, the A-address register contains an 
address (206) designating a main memory location, which in turn contains a unit of information 
(the decimal digit 7) to be added in the arithmetic unit. 



REGISTER CONTENTS OF 




Figure 2-6. Typical Control Register Function 

When the Scientific Unit (Feature 1100) is included in a Series 200 processor, each control 
register is three characters (18 bits) in length. When the Scientific Unit is not present, each 
control register is only as large as it need be to contain the largest (or "highest") main memory 
address in a user's processor. (The binary addressing technique used by Series 200 proce s sor s 
is described in Section 4. ) Thus, a processor whose main memory capacity is 8, 192 characters 

^When the Series 200 model is equipped with the Scientific Unit (see Appendix F), 12 control 
memory locations form four floating-point accumulators; these registers should only be ad- 
dressed by the scientific instructions included in that feature. 
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contains control memory registers which are each 13 bits long (13 bits allow 8, 192 addresses), 
while the control registers of a processor containing 131, 072 characters of main memory storage 
are each 17 bits long (see Table 2-1). 



Table 2-1. Size of Control Memory Registers 



MAIN MEMORY 

CAPACITY 

(Characters) 


4, 096 


8, 192 


16, 384 


32, 768 


65, 536 


131, 072 


262, 144 


SIZE OF 
CONTROL 

REGISTER (Bits) 


12 


13 


14 


■ 


16 


17 


18 



Control registers can be addressed either by programmed instruction or from the oper- 
ator's control panel or console. For instance, an instruction can change the course of a pro- 
gram by manipulating the contents of the control register that governs program sequence; the 
operator can interrogate a control register to determine the exact location at which the program 
has halted, etc. When a register is addressed by programmed instruction, it is specified by 
means of a variant character in the instruction. A register is addressed from the control panel 
or console by using the register's octal address. The functional name of each register and the 
variant character which specifies the register are listed in Table 2-2. 



Table 2-2. Control Memory Registers 



MNEMONIC 

DESIGNATION 


FUNCTION 


VARIANT 

CHARACTER 






1. 


AAR 


A-Address Register 


67 


2. 


BAR 


B-Address Register 


70 


3. 


SR 


Sequence Register 


77 


4. 


CLCl 


Read/Write Channel 1 - Current Location Counter 


01 


5. 


CLC2 


Read/Write Channel 2 - Current Location Counter 


02 


6. 


CLC3 


Read/Write Channel 3 - Current Location Counter 


03 


7. 


SLCl 


Read/Write Channel 1 - Starting Location Counter 


11 


8. 


SLC2 


Read/Write Channel 2 - Starting Location Counter 


12 


9. 


SLC3 


Read/Write Channel 3 - Starting Location Counter 


13 


10. 


WRl 


Work Register 1^ 


75 


11. 


WR2 


Work Register 2^ 


74 


12. 


WR3 


Work Register 3^ 


60 




|l3. 


CSR 


Change Sequence Register 


64 
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Table 2-2 (cont). Control Memory Registers 



MNEMONIC 

DESIGNATION 


FUNCTION 


VARIANT 

CHARACTER 




14. EIR 


External Interrupt Register 


66 


FEATURE 016 


15. CLCl' 


Read/ Write Channel 1' — Current Location Counter 


05 


16. SLCl' 


Read/Write Channel 1' — Starting Location Counter 


15 


FEATURE 1115 


17. CLC4 


Read/Write Channel 4 — Current Location Counter 


21 


18. CLC5 


Read/ Write Channel 5 — Current Location Counter 


22 


19. CLC6 


Read/Write Channel 6 — Current Location Counter 


23 


20. CLC4' 


Read/Write Channel 4'— Current Location Counter 


25 


21. SLC4 


Read/ Write Channel 4 — Starting Location Counter 


31 


22. SLC5 


Read/Write Channel 5 — Starting Location Counter 


32 


23. SLC6 


Read/Write Channel 6 — Starting Location Counter 


33 


24. SLC4' 


Read/ Write Channel 4'— Starting Location Counter 


35 




25. 




41 


26. ACO 


Floating-Point Accumulator 0 


42 


27. 




43 


28. 




45 


29. ACl 


Floating-Point Accumulator 1 


46 


30. 




47 


31. 




51 


32. AC2 


Floating-Point Accumulator 2 


52 


33. 




53 


34. 




55 


35. AC 3 


Floating-Point Accumulator 3 


56 


36. 




57 


Iliiiiiiiiililiiiiiiii® 


37. HR 


Internal Interrupt Register 


76 


^Not accessible to the program. 



ADDRESS REGISTERS 

The A- and B-address registers, the two sequence registers, and the interrupt registers 
are used to address main memory during the loading and execution of instructions. A detailed 
description of these registers is presented in Section 4, "Addressing. " 
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READ/WRITE COUNTERS 

Data is transferred between the main memory and a peripheral device via a read/write 
channel (described in Section 1). Associated with a read/write channel are two location counters: 
a starting location counter and a current location counter. When a peripheral transfer is to be 
performed, the address at which the transfer is to begin is stored in both counters. Then, as 
each successive character is transferred, the contents of the current location counter are in- 
cremented by one so that when the transfer is completed, the address of the character position 
immediately following the last character transferred is stored in the current location counter. 

The availability of the starting and current addresses associated with an input/output area 
greatly simplifies the manipulation of variable -length records. 

ARITHMETIC UNIT 

Arithmetic and logical operations are performed by a configuration of components commonly 
referred to as the arithmetic unit. Basically, this unit is composed of an adder, capable of per- 
forming both binary and decimal arithmetic, and two operand storage registers, each capable of 
storing a single six-bit character. In general terms, an arithmetic or logic operation is per- 
formed as follows (see Figure 2-7): 

1. An instruction in the stored program specifie s the type of operation to be per- 
formed and the main memory storage locations of the data to be operated upon. 

2. The operands are transferred to the operand storage registers a character 
at a time, beginning with the rightmost character in each operand. 

3. Each pair of characters that enters the storage registers is combined by 
the adder and the result is stored in the main memory as specified by the 
stored program instruction. If a carry is generated, it is stored in the 
adder and combined with the next higher-order pair of characters. 




Figure 2-7. Data Flow Between Main Memory and Arithmetic Unit 



^The contents of these registers are not accessible to the programmer. 
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CONTROL UNIT 

The control unit is the hub of central processor activities (see Figure 2-8). Its major 
function is to select, interpret, and execute all of the instructions in the stored program. In 
carrying out these instructions, the control unit coordinates the various activities of receiving 
data from input devices, transferring data within the central processor, and transferring proc - 
essed data to the output units. The main memory addresses used by the control unit in perform- 
ing these tasks are stored in the registers of the control memory. 




Figure 2-8. Control Unit Activities 



INPUT/OUTPUT TRAFFIC CONTROL 

The input/output traffic control is, as its name implies, the control unit which regulates 
the flow (or "traffic") of data transferred during input/output activities. It works in conjunction 
with the central processor control unit to allocate central processor time to input/output oper- 
ations and to identify the peripheral controls which are to use that time to transfer data (see 
Figure 2-9). 



The I/O traffic control enables from three (Model 200 minimum) to eight (Model 2200 
maximum) simiultaneous input/output operations to occur concurrently with the internal compu- 
tations of the processor. This simultaneity is achieved by the traffic control's allocation of 
consecutive memory cycles to either peripheral controls or the central processor. 
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Figure 2-9. Input/ Output Traffic Control Activities 
MEMORY CYCLE DISTRIBUTION 

When peripheral operations are in progress, a variety of mechanical activities may be 
taking place - paper advancing in a printer, a tape reel backspacing, a magnetic tape strip being 
selected, etc. During peripheral operations, only a fraction of actual central processor time 
is required to transfer information to and from the main memory; most of the time is taken up 
by the peripheral mechanical activities. The periods in which the central processor is actually 
interrupted for data transfer are spaced over the duration of the peripheral operation (see 
Figure 2-10). 
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REQUIRED TO COMPLETE PERIPHERAL OPERATION 
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1^1 TIME 
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n 
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■ ^ t 1 

L- CENTRAL PROCESSOR TIME REQUIRED FOR DA 


1 1 

TA TRANSFER 




L i 


i 



Figure 2-10. Data Transfer Intervals During One Peripheral Operation 



When a peripheral operation is in progress but is not using main memory (the gray areas 
in Figure 2-10), another peripheral control may gain access to the main memory. This second 
memory access can in turn give way to a third access by another control before the original 
operation requires access to the memory again, etc. In other words, peripheral operations can 
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occur simultaneously with one another. The periods of time in which peripheral controls do not 
require main memory access to transfer data are given to the central processor for its internal 
activities. It is the function of the I/O traffic control to direct the sharing of main memory 
cycles by the various peripheral devices and the central processor. 

The rate at which each peripheral control transfers data over a programmer -as signed 
read/write channel depends on the mechanical characteristics of the device connected to the 
control. Thus, the transfer intervals shown in Figure 2-10 are spaced according to the device 
being used. For instance, the transfer rate for the mass memory file is considerably faster than 
that for the card punch; therefore, the mass memory file will require access to the main memory 
more frequently than the card punch. The I/O traffic control monitors the requests for access 
to the main memory and insures that all requests are honored within the prescribed time interval 
for each unit. The manner in which this is done is illustrated in Figure 2-11. Essentially, 
the traffic control decides how each memory cycle should be used — by a read/write channel or 
by the central processor - as described below. 

The traffic control offers consecutive memory cycles to read/write channels, one memory 
cycle per channel. If there is a demand on a particular channel when the cycle is offered, the 
channel is granted access to the main memory for one cycle. If the channel does not require 
the memory cycle (i.e. , if there is no information to be transferred through the channel at that 
time), the memory cycle is given to the central processor for internal data processing. 

Each basic read/write channel associated with a processor is granted a memory cycle 
access to the memory every six microseconds. Thus, the Model 200 processors grant a two- 
microsecond access to each one of the three basic read/write channels every six microseconds; 
the Type 2201 processor gives a one -microsecond memory access to each one of six basic 
channels every six microseconds . The Type 1201 processor also offers a memory cycle (1.5 
microseconds) to each of the three basic channels every six microseconds but in a slightly 
different manner. There are four 1.5-microsecond memory cycles in every six-microsecond 
interval. Thus, RWCl, RWC2, and RWC3 are each granted a 1. 5-microsecond access to the 
memory, and 1. 5 microseconds is still available before the next six-microsecond interval 
begins. This "residual" memory cycle is always given to the Type 1201 processor for internal 
computation. 

AUXILIARY READ/ WRITE CHANNELS 

RWCl' and RWC4' are called auxiliary read/write channels because of the manner in which 
they are granted access to the main memory by the input/output traffic control. RWCl and 

iRead/write channels are described in Section 1. 
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*THIS INTERVAL COMPRISES TWO MEMORY CYCLES IN THE TYPE 1201 PROCESSOR', 
THE FIRST CYCLE IS GIVEN TO RWC3 {AS SHOWN), THE SECOND CYCLE IS GIVEN 
TO THE PROCESSOR. 



Figure Z-11. Symbolic Representation of Input/Output Traffic Control 
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RWCl' are connected to an alternator; RWC4 and RWC4' are also connected to an alternator. 
Every six microseconds, either or both alternators (depending on the number of channels asso- 
ciated with a processor) switch to allow one of the attached read/write channels access to the 
main memory. By providing alternate access between RWC's 1 and 1' and between RWC's 4 and 
4', each auxiliary RWC can gain access to the main memory once every 12 microseconds. 

It should be noted that program control of the alternators is required because the data 
transfer characteristics of certain peripheral devices require that main memory be accessed at 
intervals less than 12 microseconds. This means that when such devices are linked to the main 
memory via RWCl and/or RWC4, the action of the appropriate alternator must be inhibited. 
Under no conditions should such devices be assigned to transmit data over RWCl' or RWC4'. As 
discussed in Section 8, input /output instructions can be specified to inhibit the action of the 
alternator (s), thereby guaranteeing RWCl and/or RWC4 access to the main memory every six 
microseconds by denying memory access to the corresponding RWC(s). 



Table 2-3. Summary of Central Processor Characteristics 



[jliiii 


201 




201-2 








PROCESSING UNIT 


Six-bit character. Groups of consecutive characters form instruc- 
tions and data fields. Fields are defined by word mark punctuation 
(see Section 3). 


INSTRUCTION FORMAT 


Variable. Typical configuration: op code, two addresses, and 
variant character. 


ADDRESSING MODES 


Two-, three-, and four -character addressing. Three- and four- 
character addresses can specify indexed and indirect addressing. 


MEMORY CAPACITY 
(Characters) 


2, 048- 
32, 768 


2, 048- 
65, 536 


4, 096- 
65, 536 


16, 384- 
131, 072 


16, 384- 
262, 144 


MEMORY CYCLE 
(Microseconds) 


2 


2 


2 


1.5 


1 


INDEX REGISTERS 


0-6 


0-15 


0-15 


15-30 


15-30 


1 CONTROL MEMORY 


MEMORY CAPACITY 
(Control Registers) 


12-16 


13-16 


13-16 


16-29 


16-37 


MEMORY CYCLE 


0. 50 microseconds 


1 AmTHMETiC UNIT 


1 OPERATIONS 


Decimal arithmetic, binary arithmetic, logical operations. 


TYPICAL 

OPERATING 

SPEEDS (3- 

Character 

address 

mode) 


5 -Digit 

Decimal 

Add 

(A+B--B) 


48fJLS 


48 (Jis 


48 [OS 


36(03 


2 4 [OS 


5 -Digit 

Compare 

(A;B) 


38(0.3 


38|jis 


38[xs 


30 [OS 


2 1 [OS 
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Table 2-3 (cont). Summary of Central Processor Characteristics 



1 PROCESSOR 


■-'.-zoi-. 




201-2 


.. • 


2201 


1 . -L .V -CONTROLUNIT 


CHECKING 


One parity bit with each character. 


PROGRAM CONTROL 


Sequential selection, interpretation, and execution of all stored- 
program instructions. 


I INPUT /OUTPUT TRAFFIC CONTROL 


READ/WRITE 

CHANNELS 


3-4 


3-4 


3-4 


4 


4-8 


INPUT /OUTPUT 
TRUNKS 


8-16 


8-16 


8-16 


16 


16-32 


SIMULTANEOUS 

OPERATIONS 

POSSIBLE 


3-4 


3-4 


3-4 


4 


4-8 
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VARIABLE FIELD LENGTH 

Information is stored in the main memory in groups of characters, which are called fields. 
A field is, by definition, any group of characters that is treated as a unit. Series 200 models 
permit fields of any length, from one character up to the maximum number of characters in the 
memory. This means that an instruction or data field occupies only that number of core storage 
locations actually needed. 



The use of variable -length fields requires that there be a method of indicating the actual 
length of instruction fields and data fields. This requirement is fulfilled by the word-mark bit 
mentioned in Section 2. The word-mark bit performs the following functions: 

1. It terminates the retrieval of an instruction. 

2. It terminates the execution of an instruction. 

3. It defines the size of a data field. 



Throughout this manual, the presence of a word mark will be indicated by a circle around 
the character with which it is associated. The following points should be noted regarding the 
use of word marks: 

1. Word marks can be set and cleared by programmed instructions. 

2. Word marks are set by the same routine that loads a program and data into 
the main memory. Usually, word-mark assignments will remain unchanged 
throughout the execution of a program. 

3. An instruction is terminated by a word mark in the storage position immediately 
following its last (rightmost) character. 

4. A data field is terminated by a word mark associated with its high-order 
(leftmost) character. 
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INSTRUCTION FORMAT 

An instruction is a coded statement which orders the computer to perform a fundamental 
operation. A set of instructions suitably combined to perform a specific task is called a program 
or routine. 

As will be shown in Section 5, the task of coding the instructions in a program is greatly 
simplified by the Easycoder symbolic programming system. The Easycoder Assembly Program 
converts the symbolic coding written by the programmer into a machine language which is ac- 
ceptable to the internal logic of the machine. 

OPERATION CODE 

Basic to all instructions is an operation code, usually referred to as an op code, that de- 
fines the fundamental operation to be performed. The programmer specifies an op code by using 
a predefined mnemonic configuration; e.g. , BA is the op code that specifies a binary add opera- 
tion, MCW is the op code that specifies a move characters to word mark operation. The Easy- 
coder Assembly Program automatically converts a mnemonic op code into a single -character, 
machine -language op code and sets the word-mark bit in the character position in which it is 
stored. 

A AND B ADDRESSES 

Most instructions also have two address portions, designated as the A address and the 
B address. The address portions indicate the starting locations of the operand fields in the 
main memory. Using the Easycoder language, the programmer can specify memory locations by 
means of symbolic addresses or "tags" (see Section 5). 

The Easycoder Assembly Program automatically assigns absolute memory addresses to 
the symbolic addresses appearing in a program (see Figure 3-1). Thus, the programmer can 
manipulate operands without regard to their actual storage locations in memory. 




Figure 3-1. Conversion of Symbolic Tags to Absolute Memory Addresses 
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Because of the modular design of Series 200 models, the programmer has the facility to 
specify whether a two-, three-, or four -character absolute address will be assigned to each 
symbolic address used in the program. In any case, the absolute addresses assigned by the 
assembly program are interpreted as pure binary numbers (see Section 4). 

VARIANT CHARACTER 

The variant character is used to modify the op code of an instruction. For example, the 
op code of a Branch on Condition Test instruction (BCT) specifies the fundamental operation — 
branch if a tested condition is met. The condition or restriction which must be met before the 
branch can occur is specified by the variant character. A table of valid variant characters is 
presented in Appendix B. 

Figure 3-2 shows the six basic formats in which machine -language instructions may appear. 
Since the maximum number of characters in an instruction depends upon whether two-, three-, 
or four -character addressing is being used, shaded boxes in the illustration indicate the format 
of an instruction without specifying the number of characters in each part. These formats are 
representative of all instructions except those associated with input/output operations. The for- 
mat of an input/output instruction (shown in Section 8 under the heading "Input /Output Instruc- 
tions") is a modification of format 3 shown below. Specifically, the variant characters of the 
instruction are replaced by a field of one or more control characters which define the input /output 
operation in terms of data path, direction of data flow, control unit designation, etc. 




Figure 3-2. Series 200 Instruction Formats 



For the sake of direct comparison. Figure 3-3 illustrates each of the formats defined in 
Figure 3-2 as a symbolic entry on the programmer's coding form. 
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EASYCODER 

COOING FORM 



PROBLEM PROGRAMMER DATE PAGE OF 



CARD 

NUMBER 


T 




LOCATION 


OPERATION 

CODE 


OPERANDS 




1 2 1 3 4| 5 


6 


7 


8 I 14 


15, 20 


2', . . . 1 , , . , 1 . . . . 1 . 1 1 , 1 , , . , 1 


63, , . ,80 


1 1 








6,CE 


P6, LA, BEL, .06 . . . , 


F0,R,MA,T. .1, . , , , , . 














. 1 . . . . 1 . , , . 1 I . 


. 1 1 








A 


ITEM,, total . , 
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1 1 










T 


_J ■ 1 . . 1 ■ i__J 1 J . ■ ■ ■ 


1 1 
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FOR.MAT .3, , , 


1 1 
















FO.R.MAT 4, , , , 
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. ■ i ■ 1 1 1 L__J 1 1 


1 1 
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Si ... . 
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. I 1 1 ... . 


1 1 












■ ■ l x . , 1 , I L...X._L— L— 


1 














! 1 












■ ■ 1 . 1 ■ ■ 1 ■ 
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1 1 ■ ■ ■ 1 


. . t . . . . 1 . ■ . . .-L ^ -i—j. -x_J . 1 . . i . 1 . . . . 1 1 


■ . 1 .... 1 .... 1 ... ■ 



Figure 3-3. Symbolic Representation of Series 200 Instructions 

ORGANIZATION OF DATA IN MAIN MEMORY 

Data may be stored in the main memory in any of the following variable -length formats: 

• FIELD 

• ITEM 

• RECORD 



FIELDS 

Consider the eight consecutive storage locations shown in Figure 3-4. To indicate to the 
machine that these eight characters are to be treated as a field , their left and right boundaries 
must be defined. The left boundary is defined by setting a word mark in position 990. The right 
boundary is defined by specifying storage address 997 in the instruction that will manipulate the 
field. The eight -character group shown in Figure 3-5 is properly defined as a field. 




Figure 3-4. Consecutive Storage Locations in Main Memory 
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ORGANIZATION OF DATA IN MAIN MEMORY 



CARD 

NUMBER 


I 


0 

j LOCATION 


1 OPERATION 
CODE 


1 .2 |3 ,4| 5 




’ 8, , , , , .14 


15, 20 


1 1 
- ■ 1 ■ 1 






A . . . 



EASYCODER 

CODING FORM 

PROGRAMMER . 



. PAGE 0F_ 



OPERANDS 



1 307 .^ 7 



XL 



-ADDRESS PORTION OF INSTRUCTION 



STORAGE ADDRESS' 
CONTENTS- 





991 


992 


993 


IHi 


995 


996 


997 




3 


6 


6 


9 


5 


2 


9 



WORD 

MARK 



DATA FIELD 



Figure 3-5. Data Field Format in Main Memory 



ITEMS 

An item consists of one or more consecutive storage locations whose boundaries can be 
defined in either of two ways: 

1 . The leftmost character position can be definedinthe instruction that will operate 
on the item and the rightmost character position definedby an item mark; or 

2, The rightmost character position can be defined in the instruction that will oper- 
ate on the item and the leftmost character position defined by an item mark. 

NOTE: An item mark is illustrated in this manual by underlining the character with 
which it is associated. Fields within an item are defined by word marks. 

Two items, each containing three data fields, are shown in Figure 3-6. 



ADDRESS PORTION 
OF INSTRUCTION 



STORAGE ADDRESS- 
CONTENTS- 



iiill 

- 


iiiiii 


IIIIII 


703 


mm 


iilli 


iilii 


707 


7^^ 


700 


710 




7 


6 


© 


3 


9 


7 


® 


4 


2 


8 


Udata fields 


■^DATA 


FIELD ► 


-•-DATA FIELD ► 



ITEM 



ITEM 

"mark 



ADDRESS PORTION 
OF INSTRUCTION 



STORAGE ADDRESS 
CONTENTS 

ITEM MARK- 



342 


343 


344 


Piii 


346 


347 


343 1 




© 


2 


© 


0 


® 


3 


li 


^DATA ^ 
FIELID 


^ DATA ^ 
FIELD 


^DATA ^ 
FIELD 




1^ J 


± HjIVL 





Figure 3-6. Two Item Formats in Main Memory 
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RECORDS 

A record is any unit of information that is to be transferred between the main memory and 
a peripheral device. ^ A record can be of any length, from one character up to the maximum 
number of characters in the memory. It can contain any number of items and fields. The right- 
most limit of a record is defined by a record mark in the character position following the last 
character in the record (see Figure 3-7). 

NOTE: A record mark is illustrated by combining the word-mark and item-mark 
symbols. The address of the leftmost character in a record is specified 
in the instruction that operates on the record. 



ADDRESS PORTION OF INSTRUCTION 



STORAGE ADDRESS 
CONTENTS 




Figure 3-7. Record Format in Main Memory 



SUMMARY 



The foregoing data formats are summarized in Figure 3-8. 



DATA FORMAT 


BOUNDARY DEFINITION 


INSTRUCTION 

TtCtTFi Tn QtT'np 

MARK (See 
Section 8) 


LEFTMOST CHARACTER 


RIGHTMOST CHARACTER 


FIELD 




Address portion of in- 
struction 


Set Word Mark 


ITEM 


Address portion of in- 
struction 


Item mark X 


Set Item Mark 


Item Mark X 


Address portion of in- 
struction 


RECORD 


Address portion of in- 
struction 


Record mark 

(in character position 
following last character 
of record)^ 


BOTH Set 
Word Mark 
and Set Item 
Mark 



Figure 3-8. Summary of Internal Data Formats 



^ A record can also be moved internally (i.e. , from one main memory area to another) by means 
of the Extended Move instruction (see Section 8). In this case, the character containing the 
record mark is considered as part of the record. 
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MAGNETIC TAPE DATA FORMAT 

In many applications, a major input and output medium for a Series 200 model is magnetic 
tape. The standard Series 200 magnetic tape system uses 1 /2-inch tape as the recording medi- 
um. A tape system using 3/4-inch tape is also available. 

Information is stored on 1 /2-inch magnetic tape in variable -length group of characters 
called records. The tape is divided lengthwise into seven recording channels. A line of bit posi- 
tions across the tape, one position for each channel, is called a frame. The seven bits in a 
frame correspond to the six information bits and one parity bit found in a character position in 
the main memory. Notice that no channels are provided for the storage of punctuation bits on 
tape. Unlike main memory records, which are delimited by record-mark punctuation, tape rec- 
ords are separated from each other by a band of blank tape, which is called an interrecord 
gap. The representation of a memory character position on magnetic tape is shown in Figure 3-9. 




Characters recorded on magnetic tape are transferred from the main memory without 
parity bits. At the time of recording, the magnetic tape control generates parity bits as 
required. The programmer may specify either odd or even-parity recording: in the odd-parity 
mode the bit count in each frame is odd; in the even-parity mode the bit count is even. 

In addition to parity bits, which are used for frame checking, the magnetic tape control 
also generates a longitudinal check frame which is used for channel checking purposes. A check 
frame is automatically appended at the end of each record stored on tape. 

Recall that a record stored in memory is delimited by a record mark in the character 
position following the last character in the record. When a record is transferred to tape, the 
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contents of the character position containing the record mark are not included as part of the re- 
cord. On the other hand, if a record mark is sensed in memory when information is being read 
in from tape, the record mark will terminate the record and the character position containing 
the record mark will receive a character from the tape. Although data transfer from the tape 
is terminated by the record mark, tape motion continues until an interrecord gap is sensed. 

No punctuation marks are altered in any way as a result of tape read/write operations. 




Figure 3-10. Data Format on Magnetic Tape 



PUNCHED CARD FORMAT 

Punched cards provide a convenient means of entering data into the machine. The cards 
used for this purpose are either standard 12-row, 80-column cards or 51-column cards. Each 
card column may contain a decimal digit, an alphabetic character, or a special symbol such as 
a slash or an asterisk (see Figure 3-11). 



ZONE 

PUNCHES 



// 



0 I 23456789 



NUMERIC 

PUNCHES 



80 COLUMN 
SCALE 



ABCOEFGHI 

lllllllll 



JKLMNOPQR STUVWXYZ 



lllllllll 



III 

III 



OOOOOOO.OlOOOOOOOOOQOOOOOOOOOOOOOOOOOOODUDOOOOO lllllllloo 000 0000 oooollloo 0000 0000 

1 J 3 4 S 6 j I 9 10 tl »? »3 14 15 16 17 H 19 2C 2! 22 73 24 25 26 27 26 79 30 31 32 33 24 35 36 17 36 39 40 41 4? 41 44 45 *6 4l 48 4S 50 51 52 53 54 55 56 5J 58 53 60 61 62 63 64 o5 66 6? 65 69 70 71 72 73 74 75 76 77 78 79 60 

I M 1 1 1 n 1 1 1 1 1 1 1 1 n n 1 1 1 1 1 1 1 1 1 1 1 1 1 1 n 1 1 1 n 1 1 11 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 
2222222222 | 2222222222222222 | 222222222 | 22222222|222222222222222222222222222222222 
33333333333|3333333333333333|333333333|33333333n33333333333333|33|33|3|333333333 
444444444444|4444444444444444|444444444|44444444|44444444444444|44|44|4|44444444 
5555555555555|5555555555555555|555555555|55555555|555555555555555555555b55555555 
66666666666666|6666066666666666|6666B6S66|E6666666|66668f>68666666666666666666666 
1 7 7 7 7 7 7 7 7 7 7 7 7 7 7 | 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7l 7 7 7 7 7 ; 7 7 7| 7 7 7 7 ; 7 7 7 | 7 7 ; 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 ; 7 

3l888888388B888B88|888888838|888l!888e|888888888ll8ll8lllll 



ogooooooooooooosoloooooooooooooooolooooooogoloooooooolooooooooooossooooooooooooo 

1 2 3 < S 4 7 8 9 !0 )1 12 13 14 15 16 <) II 19 20 2‘ 27 73 2< 75 26 V 21 79 M Ji 1? Jl 74 35 )6 Ji 38 3i> 40 41 42 4} M 45 46 47 4fl 49 50 51 52 53 54 S5 56 57 58 59 80 6' 82 6j 64 65 66 61 68 69 10 1' 'J 13 14 15 16 11 10 19 80 



Figure 3-11. Punched Card Codes 
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PUNCHED CARD FORMAT 



Nixmeric information is represented using the card punch positions labeled zero through 
nine. Alphabetic information is represented by a combination of numeric punches and zone 
punches. There are three zone punch positions: the 12 zone at the top edge of the card, the 11 
zone just below the 12-zone position, and the zero zone labeled as row zero on the card. The 11 
and 12 zones are not labeled because the top edge of the card is reserved for printed headings . 

In addition to Hollerith code, cards may be punched or read in the direct transcription 
mode as an optional feature. Each punch position on the card is individually significant in this 
mode, a punch representing a one bit and the absence of a punch representing a zero bit. 

The data formats of the media most commonly associated with peripheral devices (viz. , 
magnetic tape and punched cards) have been described. However, other media (e. g. , paper tape, 
magnetic tape strips, etc. ) also contain unique data formats which are converted to central 
processor format by their respective peripheral controls. These formats are described in the 
individual Series 200 publications which define such devices. 
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BASIC CONCEPTS 

The main memory storage locations that contain the instructions and data of a program are 
identified to the machine by their particular main memory addresses. Every character storage 
location in the main memory is directly addressable. 

An instruction is stored in a field of from one to 12 characters, depending on the format of 
the instruction and the mode of address assembly (two--, three-, or four-character). Figure 4-1 
illustrates how a typical Add instruction appears when stored in the main memory. (Recall that 
a character enclosed in a circle indicates that a word mark is associated with it. ) 

An instruction is addressed by specifying the op code (leftmost) location of the instruction. 
For instance, the address of the Add instruction in Figure 4-1 is storage location 524. The 
machine reads an instruction from left to right until it senses a word mark. For example, the 
extraction of the Add instruction (Figure 4-1) is stopped by the word mark associated with the 
op code of the next instruction in sequence. 




Figure 4-1. Typical Add Instruction 
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As mentioned in Section 3, a data field is defined in the following manner: the leftmost 
location in the field is indicated by a word mark; the rightmost location is specified in the A or 
B address of an instruction. The machine reads a data field from right to left until it senses the 
word mark associated with the leftmost character in the field. For example, the A and B ad- 
dresses in the instruction shown in Figure 4-1 could specify the data fields shown in Figure 4-2. 



ADDRESS- 

DATA- 



ADDRESS- 

DATA- 



OP 

CODE 



A ADDRESS 



B ADDRESS 



INSTRUCTION 



1776 



1492 






1771 


1772 


1773 


1774 


1775 


:i7;7b:^ 


1777 


► 


4 


© 


7 


2 


0 


4 


© 



A FIELD 



■.4485: ■ 


1486 


1487 


1488 


1489 


1490 




1492 


1493 


© 


3 


7 


7 


7 


3 


9 


6 


© 







B FIELD 

MACHINE READS DATA FIELD 



FROM RIGHT TO LEFT 



Figure 4-2. Extraction of Data Fields in Typical Add Instruction 



An item is addressed by specifying either its leftmost or its rightmost character location 
in an address portion of an instruction (a variant character in the instruction specifies which 
character is being addressed). If the address of the leftmost character is specified, the ma- 
chine reads the item from left to right ; if the address of the rightmost character is specified, 
the machine reads the item from right to left. In either case, the operation terminates when an 
item mark is sensed. 



A record is addressed by specifying its leftmost character location in an address portion 
of an instruction. The machine reads a record from left to right until it senses a record mark. 
Note that the contents of the character position containing a record mark are not considered as 
part of the record. 



^NOTE: All examples and illustrations in this section are presented in decimal notation. A table 
of decimal and octal equivalents appears in Appendix A. 
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REGISTERS USED IN ADDRESSING 



The direction in which the machine reads any of the above-mentioned groups is compatible 
with the manner in which the contents of the group are manipulated. For instance, a field is 
read from right to left becuase arithmetic operations combine fields character by character, 
starting with the low-order or "units" position in each field. Similarly, an instruction is read 
from left to right because the machine must interpret the op code before it can manipulate the 
operand(s). 



REGISTERS USED IN ADDRESSING 

The processing of a stored-program instruction consists of two phases: the retrieval (or 
"extraction") of the instruction from main memory storage, and the execution of the instruction. 
Six control memory registers are used to address the main memory during instruction proc- 
essing. Four registers — SR, GSR, EIR, and IIR — are related to the sequential selection of 
instructions in a program; the other two registers — AAR and BAR — control the transfer of 
information from one storage location to another by containing the address portions of an in- 
struction. 

SEQUENCE REGISTER (SR) 

SR contains the address of the next sequential instruction character to be extracted from 
the memory during a program run. The contents of SR are incremented by one as each instruc- 
tion character is extracted, so that SR contains the address of the next instruction's op code 
when one instruction has been completely extracted. 

CHANGE SEQUENCE REGISTER (GSR) 

The address of an op code can be stored in CSR. ^ A Change Sequencing Mode instruction 
(see page 8- 72) will interchange the contents of SR and CSR and thereby cause the program to 
branch to the instruction whose op code address was stored in CSR. At this point in the program 
CSR will contain the address of the op code following the Change Sequencing Mode instruction. 

In order to return to this op code (i. e. , to the initial sequence of instructions), another Change 
Sequencing Mode instruction can be issued. 

EXTERNAL INTERRUPT REGISTER (EIR) 

EIR, like CSR, can be used to store the address of an op code (see footnote below. This 
address and the contents of SR will be interchanged automatically when an external interrupt 
signal is received. (Recall that an external interrupt signal can be generated by a peripheral 



^A Load Control Registers instruction can be used to store the desired op code address (see 
page 8-67). 
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control, by the control panel or console, or by the Monitor Call instruction. In order to re- 
turn to the normal sequence of instructions that was interrupted, a Resume Normal mode in- 
struction (see page 8-97) can be issued. 



INTERNAL INTERRUPT REGISTER (HR) 

The address of an op code can also be store din HR. 1 When the Type 1 201 or 2201 processor is 
equipped with the Storage Protect Feature, certain operations are considered as "violations" of 
storage protection (e. g. , the attempt to transfer data from a peripheral control to the protected 
memory area). An internal interrupt signal is generated when such a violation occurs, and the 
contents of HR and SR are automatically interchanged. The Resume Normal Mode instruction is 
used to return to the interrupted program. 

A -ADDRESS REGISTER (AAR) 

AAR normally contains the A-address portion of an instruction (i.e., the storage address 
of the rightmost character in the A-operand field). This address is loaded into AAR during the 
extraction phase of processing. In the execution of instructions whose operands are fields, the 
contents of AAR are decremented by one as each character in the A field is manipulated. The 
contents of AAR are incremented by one as each character in a record or leftmost-addressed 
item is executed. 

B -ADDRESS REGISTER (BAR) 

Normally the B-address portion of an instruction is loaded into BAR during the extraction 
phase. During the execution of most instructions, the contents of BAR are decremented by one 
as each character in the B field is executed. If the B operand is a record or a leftmost-ad- 
dressed item, the contents of BAR are incremented by one as each character is executed. 

SUMMARY 

The foregoing information can be summarized as four easily remembered rules; 

1. An instruction is read from left to right . As each character in the instruc- 
tion is read, the contents of the sequence register are incremented by one. 

2. A field is read from right to left . As each character in a field is read, 

the contents of the corresponding address register are decremented by one. 

3. A record is read from left to right . 2 As each character in a record is read, 
the contents of the corresponding current location counter are incremented 
by one. 

A Load Control Registers instruction can be used to store the desired op code address (see 
page 8- 67). 

2 

A record also can be moved internally from right to left by means of the Extended Move in- 
struction (see Section 8). 
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4. An item can be read either from left to right or from right to left . As 

each character in an item is read, the contents of the corresponding ad- 
dress register are incremented by one if reading from left to right, or 
decremented by one if reading from right to left. 



Recall that a control memory register is only as large as it need be to contain the largest 
main memory address in a user's processor (see Table 2-1), so that the size of the user's 
control registers ranges from 1 2 to 18 bits in length. The programmer should keep this fact in 
mind while reading the following description of addressing modes. 



ADDRESSING MODES 

As stated at the beginning of this section, an instruction is stored in a field of from 1 to 12 
characters, depending on the instruction's format and the programmed addressing mode. The 
op code is stored as a single, six-bit character. Variant characters or I/O control characters, 
if any, are each stored as single characters. The number of character locations in which each 
address portion is stored depends on the addressing mode selected by the programmer. This 
selection is made by means of a Change Addressing Mode instruction (see page 8-69), by which 
the programmer specifies the two-, three-, or four-character addressing mode. A significant 
feature of the Series 200 addressing technique is that the entire memory is directly addressable. 



TWO -CHARACTER ADDRESSING MODE 

An operand address written in the two -character addressing mode is stored in two con- 
secutive character locations in memory. The stored address (a continuous 12-bit binary num- 
ber) represents the address of a main memory location in the range 0 - 4, 095 jq. 



Two-Character Address 



1 

1 JV: A ■■ 


X X X X X X 


' ,, 



1 2-Bit Addres s 



During the extraction phase of instruction processing, the two-character address is placed 
in the rightmost 12 -bit positions of the address register (AAR or BAR). Any bits in the register 
to the left of the two-character address .are called "bank bits. " Previous values in the bank bit 
positions of the register are not disturbed during instruction extraction. ^ 



The entire contents of an address register (bank bits + two -character address bits) are affected 
during the extraction of an instruction whose extraction path "duplicates A" (described on page 
4-16). Extraction of all other two-character addresses affects only the rightmost 12 bits. 



4-5 






SECTION 4. ADDRESSING 



Two-Character Address 
(12 Bits) 

Address Register 

(12 - 18 Bits) 



When the instruction is executed, the entire contents of the address register are inter- 
preted as the operand address. Previous values in the bank bit positions, not disturbed during 
the extraction phase, are used to form the address of the operand during the execution phase. 
Thus, the bank bit values are a base address to which the 12-bit address is added to form the 
actual operand address. If the bank bit values are all zeros, the 12-bit address is the actual 
operand address. 

For example, a two-character A address specifying location 4, OOOjq is extracted and 
placed in AAR. The second bank bit in AAR (bit position 14) contains a residual value of "1", 
forming a base address of 8, 192 j^q. When the instruction is executed, the entire contents of 
AAR (8, 1922Q + 4, OOO^q) specify the address of the A operand — location 12, 1922 q. 

As the contents of the address register are incremented or decremented during "internal" 
execution, bank bits are not disturbed. ^ If the 12-bit address in the rightmost positions of the 
register becomes zero, a borrow from the first bank bit does not occur. Thus, the portion of 
memory which is addressable by a two-character address is the 4, 096 -character "bank" speci- 
fied by the base address. 

Indexed and indirect addressing (see below) cannot be performed in the two-character ad- 
dressing mode. 

THREE-CHARACTER ADDRESSING MODE 

An operand address written in the three -character addressing mode is stored in three 
consecutive character locations of the memory. The rightmost 15 bits of the stored address 
represent the address of a main memory location in the range 0 - 32, 76?2 q. The leftmost three 





fillet ^ Wi 






-►ix X X X X 


"V* “V* “V" *V *V* 'V 
'.A;-. . ' .;/V J\ .A 



Bank Bits 
(not disturbed 
during 
extraction) 



"Internal execution" is defined as the incrementing or decrementing of address register con- 
tents during memory cycles allocated to the central processor. When peripheral transfer oper- 
ations are performed, using memory cycles allocated to read/write channels, incrementing and 
decrementing of address register contents affect all bits of the register. Thus, addressing 
during peripheral transfer operations is continuous throughout the memory. 
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bits, referred to as the "address modifier, " specify whether the address is direct, indirect, or 
indexed (see "Address Modification, " page 4- 8 ). 



Three-Character Address 




iJC X X- X[ Xb IX 


V ^ V Y Y 


3 -Bit 




1 5 -Bit Address 


Address 






Modifier 







During the extraction phase, the 15-bit address is placed in the rightmost bit positions of 
the operand address register. Any bits in the register to the left of these bit positions are called 
"sector bits. " Previous values in the sector bit positions of the register are not disturbed during 
instruction extraction. ^ 



Three-Character Address 
(15 Address Bits) 

Address Register 

(15-18 Bits) 






XXX 



*V“ V V V V 

.A. j\ jTV, 



-ev ^ A JSk wrV 



I ■XT’ XT’ I V V ’V’ i *V ’V V ‘V V V I V *V ‘V' “V ’V V 

I 



Sector Bits 
(not disturbed 
during 
extraction) 



When the instruction is executed, the entire contents of the address register are interpre- 
ted as the operand address. Previous values in the sector bit positions, not disturbed during the 
extraction phase, are used to form the address of the operand during the execution phase. Thus, 
the sector bit values are a base address to which the 15-bit address is added to form the actual 
operand address. If the sector bit values are all zeros, the 15-bit address is the operand address. 

For example, a three-character A address specifying location 12, OOOjq is extracted and 
placed in AAR. The first sector bit in AAR (bit position 16) contains the value "1", forming a 
base address of 32, 768^^. When the instruction is executed, the entire contents of AAR 
(32, 768 jQ + 12, OOOjq) specify the address of the A operand — location 44,7682 0* 

As the contents of the address registers are incremented or decremented during "internal" 
execution, sector bits are not disturbed. If the 15-bit address in the rightmost locations of the 
address register becomes zero, a borrow from the first sector bit does not occur. Thus, the 



The entire contents of an address register (sector bits + 15-bit address) are affected during the 
extraction of an instruction whose extraction path "duplicates A" (described on page 4-16). Ex- 
traction of all other three-character addresses affects only the rightmost 15 bits in the register 
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portion of memory which is addressable by a three-character address is the 32, 768 -character 
"sector" specified by the base address. 

Addressing is continuous throughout the entire memory when a peripheral transfer oper- 
ation is performed, as in the two-character mode. 

FOUR- CHARACTER ADDRESSING MODE 

An operand address written in the four-character addressing mode is stored in four con- 
secutive character locations. The rightmost 18 bits represent a main memory address in the 
range 0 - 262, 144 jq. ^ The leftmost five bits — the "address modifier" — specify whether the 
address is direct, indirect, or indexed (see "Address Modification, " below). 



Four-Character Address 


►lx X X X X 

1 


0 


"y* ^ 

^ 


X X X X X X 


V V 'V' v 

^ 















5-Bit 18-Bit Address 

Address 
Modifier 



The 18 -bit address is placed in the address register during the extraction phase. Thus, 
the entire contents of the address register are affected during the extraction of a four -character 
address. 



Four -Character Address 
(18 Address Bits) 



XXX xlolxxxxxxlxxxx X~^X X X X X X 



Address Register 
(Up to 18 Bits) 



I •y V V V V yI Y Y Y Y Y yTy Y Y v' V Y 
a ^ ^ A A A A. A 



The entire contents of the register are interpreted as the operand address when the instruc- 
tion is executed. As the contents of the operand address registers (AAR and BAR) are incre- 
mented or decremented during execution, all bits in the register are affected. Thus, addressing 
is continuous throughout the entire range of available memory (up to 262, 144 locations) in the 
four -character addressing mode. 



ADDRESS MODIFICATION 

Indirect and indexed addressing can be used to modify three- or four -character addresses 
in any Series 200 processor containing the Advanced Programming Feature (Feature 010 or Oil). 



The nineteenth bit of a four -character address is reserved for possible memory expansion. 
This bit is always zero in Series 200 processors with a main memory capacity of 262, 144 
characters or less. 



4-8 








ADDRESS MODIFICATION 



These addressing forms are represented by the configuration of the "address modifier" as 
described below and are interpreted by the processor during the extraction phase. 

THREE -CHARACTER ADDRESS 

The address modifier of a three-character address (i.e. , the leftmost three bits of the 
stored address) specifies whether the address is direct (000), indirect (111), or indexed (001 
through 110). 

Indirect Addressing 

In previous examples and illustrations in this section, an address portion of an instruction 
always specifies the address of a data field in the main memory. This manner of addressing an 
operand is commonly referred to as direct , or "first-level, " addressing. In some instances, 
instead of specifying the location of a data field directly, it is more useful to be able to specify 
the storage location of another address, which in turn specifies the location of the desired data 
field. This manner of locating an operand is referred to as indirect , or "second-level, " 
addressing. 

A three -character indirect address is specified by an address modifier of all one bits and 
refers to the leftmost storage location of another main memory address. The referenced address 
can itself be direct, indirect, or indexed as specified by its address modifier. Thus, an indirect 
address can specify another indirect address, and so on through any number of levels, or it can 
specify an indexed address. The method of coding an indirect address is illustrated in Section 5. 

Figure 4-3 shows the extraction of an Add instruction in which indirect addressing is 
specified in the A address and direct addressing is specified in the B address. Note that the A 
address (indirect) references the leftmost location of another main memory address. This ad- 
dress, in turn, specifies the location of the rightmost character in the A field. Note further 
that if the address modifier of location 1027 were not "000", the remainder of the stored address 
would be interpreted as an indexed or indirect address. 

Indexed Addressing 

A Series 200 processor can contain up to 30 index registers, depending on the type of proc- 
essor and the optional features included in that processor. Table 4-1 summarizes the manner 
in which a processor acquires index registers. 

Indexing operations in the three -character addressing mode use index registers 1 through 
6. These registers are located in the first 25 locations (locations 0 through 24) of the 32, 768- 
character sector in which the instruction is stored (see Table 4-2). ^ 

^ These registers are always located in the first 25 locations (locations 0-24) of memory in a 
Type 201 or 201-1 processor. 
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Figure 4-3. Extraction of Three-Character Indirect Address 



Table 4-1. Number of Index Registers Available to Series 200 Processors 



Type 


Basic 

Processor 


Features 


Minimum 


Maximum 


Advanced 
Programming 
(Feature 
010 or Oil) 


Storage Protect 
(Feature 1114 
or 1117) 


201 


0 


6 


n/a 


0 


6 


201 -1 


0 


15 


n/a 


0 


15 


201 -2 


0 


15 


n/a 


0 


15 


1201 


15 


n/a^ 


15 


15 


30 


2201 


15 


n/a^ 


15 


15 


30 



Advanced Programming is a standard feature on the Type 1201 and 2201 processors. 
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Table 4-2, Index Register Addresses in Three -Character Addressing Mode 





Address Modifier 


Storage Field 




1 


001 


2-4 (+n) 


4 (+n) 


2 


010 


6-8 (+n) 


8 (+n) 


3 


on 


10-12 (+n) 


12 (+n) 


4 


100 


14-16 (+n) 


16 (+n) 


5 


101 


18-20 (+n) 


20 (+n) 


6 


1 10 


22 - 24 (+n) 


24 (+n) 


n = first location of the 32, 768-character sector in which the instruction is 
stored. 



When indexed addressing is performed in the three -character mode, the rightmost 15-bit 
contents of an index register are automatically added to the 15-bit address field in an instruction 
Three variables must be defined in any indexing operation: (1) the index register to be used, (2) 

the address to be modified, and (3) the factor (referred to as an augment) to be added to the ad- 
dress. The index register to be used is specified in the address modifier of an address field. 
The address to be modified can be stored in the same address field or it can be stored in the 
designated index register. If the address to be modified is stored in an address field, the aug- 
ment is stored in the designated index register and vice versa. 

The modification of an address occurs in its respective address register. For instance 
if the B-address portion of an instruction is indexed, the modification is performed in BAR. 

This means that neither the original instruction stored in the main memory nor the contents of 
the index register is altered in any way. 

Normal programming, such as a load or a move operation, can be used to store a value 
in an index register. Similarly, the contents of an index register can be changed by using an 
instruction such as Binary Add or Binary Subtract. Note that since the index registers are lo- 
cated in the main memory, they can be used as normal storage locations when they are not 
being used for indexing operations. 

Figure 4-4 illustrates how the Add instruction on page 4-10 would be extracted if indexed 
addressing were specified in the A-address portion of the instruction. The method of coding an 
indexed address is illustrated in Section 5. 
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Figure 4-4. Extraction of Indexed Address in Three -Character Mode 
FOUR- CHARACTER ADDRESSING MODE 

The address modifier in a four -character address consists of the leftmost fiv e bits of the 
address (see page 4-8). The configuration of these bits specifies whether the address is direct 
(00000), indirect (10000), or indexed (00001 through 11111, skipping over 10000). 

Indirect Addressing 

Indirect addressing in the four-character addressing mode is performed similarly to that in 
the three -character mode, except that: 

1. a five -bit address modifier whose configuration is 10000 specifies indirect 
addressing; and 

2. a four-character address is extracted. 

The method of coding a four-character indirect address in Easycoder assembly language is 
identical to that used for a three -character indirect address (see Section 5). 
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Indexed Addressing 

Four -character indexed addresses to be modified by index registers 1 through 15 are 
specified by an address modifier whose configuration is 00001 through 01111, respectively. Index 
registers 16 through 30, when present, ^ are specified by the configurations 10001 through 11111 
(see Table 4-3). 



Table 4-3. Index Register Addresses in Four-Character Addressing Mode 



Index Register 


Address Modifier 

12 ! 


Storage Field 


Address 


1 


00001 


2-4 


4 


2 


00010 


6-8 


8 


3 


00011 


10-12 


12 


4 


00100 


14-16 


16 


5 


00101 


18-20 


20 


6 


00110 


22-24 


24 


7 


00111 


26-28 


28 


8 


01000 


30-32 


32 


9 


01001 


34-36 


36 


10 


01010 


38-40 


40 


11 


01011 


42-44 


44 


12 


01100 


46-48 


48 


13 


01101 


50-52 


52 


14 


on 10 


54-56 


56 


15 


01111 


58-60 


60 


16 


10001 






17 


10010 






18 


10011 






19 


10100 






20 


10101 


Same as above, only 


21 


10110 


relative to the 


4, 096- 


22 


10111 






23 


11000 


character memory bank 


24 


11001 






25 


11010 


designated by the Load 


26 


non 


Index/Barricade Register 


27 


11100 







28 


11101 


instruction (see page 8-84). 


29 


lino 






30 


11111 







Index registers 1 through 15 are located in the first 61 locations of the main memory (lo- 
cations 0 - 602 q)» each register occupying three storage locations. The situation of these reg- 
isters is independent of the location of the instruction whose address (es) is indexed. Index reg- 
ister s 1 6 through 30 are located in the fir st 6 1 locations of the "protected" memory area in the Type 
1201 or 2201 processor. (Recall that the main memory of the Type 1201 or 2201 can be logically divided 



Index registers 16 through 30 are the registers included, in the Storage Protect Feature. 
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at any 4, 096 -character bank into an "open" area and a "protected" area. The specific bank at 
which the division takes place is specified by the Load Index/Barricade Register instruction 
described in Section 8. ) 

When indexed addressing is performed in the four-character mode, the contents of the 
specified index register are added to the address field of the instruction. However, only the 
number of active address bits of the index register and the address field are combined (i. e. , 
only the number of bits which are required to address the entire memory of the user's proc- 
essor). The number of active address bits corresponds to the size of a control memory reg- 
ister (see Table 4-4). 



Table 4-4. Active Address Bits in Series 200 Processors 



Main Memory 
Capacity (Chars, ) 


32, 768 


65, 536 


131, 072 


262, 144 


Number of Active 
Address Bits 


15 


16 


17 


18 



If the main memory capacity of a user's system lies somewhere between any two figures 
in the top row of Table 4-4, the larger number of active address bits is used. For instance, if a 
processor contains 49, 152 characters, there are 16 active address bits in an index register (and 
in a control register). 

The extraction of a Subtract instruction written in the four -character addressing mode is 
shown in Figure 4-5. Indirect addressing is specified in the A address, and indexed addressing 
(via index register 13) is specified in the B address. 

EXPLICIT ADDRESSING, IMPLICIT ADDRESSING, AND CHAINING 
Consider the three instruction formats illustrated below. 



FORMAT I. 
FORMAT 2. 
FORMAT 3. 



OP CODE A ADDRESS B ADDRESS 




Format 1 corresponds to the instructions used in the preceding illustrations. The signifi- 
cant feature of this format is that the addresses of both the A and the B data fields are explicitly 
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Specified in the instruction^ For this reason the data fields are said to be '^explicitly addressed. 
In general, whenever the programmer writes the address of a data field on his coding sheet, he 
is explicitly addressing that data field (see Figure 4-6). 



INSTRUCTION- 



OP 

CODE 



A ADDRESS 
10000 ! 42800 



B ADDRESS 
OllOl! 55055 



indicates 

indirect 

address 



indicates 
index 
register 13 



ADDRESS ^ 42800 ] 42801 42802 I 428^ 

CONTENTS ► 0000(^ 17760 

indicates H 

direct 

address H 



CONTENTS- 



ADDRESS- 

CONTENTS- 







17760 


© 


4 


0 



A FIELD 

INDEX REGISTER 1 3 
50 I 51 I 52 ~ 
150 





55055 
+ 150 




55205 



REGISTER 



ADDRESS ► 55203 ~55204 55205 

CONTENTS ► @50 

B FIELD 



Figure 4-5. Extraction of Indirect and Indexed Four-Character Addresses 



EXPLICIT ADDRESS ^ 

OPCODE A ADDRESS 



B ADDRESS 



The addresses of both data fields are explicitly specified in 
the instruction. 



Figure 4-6. Series 200 Instruction Format 1 
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Format 2 has two possible interpretations (see Figure 4-7): 

1. Ten Series 200 instructions coded in format 2 cause the A address to be 
loaded into both AAR and BAR. ^ Thus, although the B -address portion of 
the instruction is omitted, the B field is explicitly addressed by the A- 
address portion. The extraction path of these instructions is said to 
"duplicate A" (see Appendix C), since the contents of AAR are duplicated 
in BAR. 

2. The A address of 18 instructions is loaded into AAR only, leaving BAR 
undisturbed. An omitted B address in any of these instructions implies 
that the previous contents of BAR will be used as the address of the B 
field. For this reason the B field is said to be "implicitly addressed, " 

and the extraction path of these instructions "preserves B" (see Appendix C). 



EXPLICIT ADDRESS 
OP CODE 



FORMAT 2a. 



A ADDRESS 



B ADDRESS 
1 



In ten instructions, the address of both data fields is explicitly 
specified in the instruction. 



IMPLICIT ADDRESS 
EXPLICIT ADDRESS 



OP CODE 



1 



A ADDRESS 



FORMAT 2b. 



ADDRESS \ 




B 

r 

I I 



previous contents 
of BAR 



In 18 instructions, the previous contents of BAR are 
implied as the address of the B field. The address 
of the A field is explicitly specified in the instruction. 



Figure 4-7. Series 200 Instruction Format 2 



In format 3, both data fields are implicitly addressed. The previous contents of AAR are 
used as the address of the A field, and the previous contents of BAR are used as the address of 
the B field (see Figure 4-8). 

Implicit addressing is extremely useful in situations where it is desired to perform a 
series of operations on data fields that are in consecutive storage locations. The use of implicit 



^The entire contents of AAR are loaded into BAR during extraction, so that all bit positions in 
BAR are identical to those in AAR. 
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addressing reduces both the time required to perform the operations and the number of memory 
locations required to store the instructions. 



IMPLICIT ADDRESS — 


1 


1 


FORMAT 3 


OP CODE 


▼ 

A ADDRESS 


▼ 

B ADDRESS 




■ 


1 1 

1 1 

t 


1 1 

1 1 

t 






1 

previous contents 


1 

previous contents 






of AAR 


of BAR 




1 The addresses of both data fields are 


implied in 




the instruction. 









Figure 4-8. Series 200 Instruction Format 3 



As an example, assume that three 10 -character fields stored in sequence are to be added 
to three other sequential fields. First, examine how this operation would be performed using 
explicit addressing. Upon completion of the first instruction, AAR contains 890 and BAR con- 
tains 690. 



© 


900 


700 


© 


890 


690 


© 


880 


680 



These are the same values that appear in the A- and B-address portions of the second instruc- 
tion. Similarly, upon completion of the second instruction, AAR and BAR contain 880 and 680 
— the A and B addresses of the third instruction. Since in each case AAR and BAR contain the 
addresses used in the next instruction, it is unnecessary to write these addresses in the instruc- 
tion. In other words, this operation could be performed using implicit addressing in the second 
and third instructions. 



@ 900 

© 

© 



700 
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Connecting instructions together so that the contents of AAR, BAR, and. the variant reg- 
ister (see below) at the conclusion of one instruction satisfy the requirements of the next instruc- 
tion is called "chaining. " Using explicit addressing in the three -character addressing mode, 21 
storage locations are required to store the instructions above and the operation takes 117 micio- 
seconds to complete on a Type 2201 processor. If the instructions were "chained, " nine storage 
locations would be used and 105 microseconds would be required to complete the operation. 

Instructions which require a variant character can also be chained by using the previous 
contents of the variant register. (The variant register is a single-character, internal register 
into which the variant character of an instruction is loaded during extraction. ) The extent of 
chaining variant characters (i. e. , the number of acceptable instruction formats in which the 
previous contents of the variant register can be used) varies with the processor being used. 

In the Types 201-2, 1201, and 2201 processors, variant characters can be chained by an 
instruction coded in any format (i. e. , format 1, 2, or 3 shown on page 4-14). The previous 
contents of the variant register are not disturbed by the processing of an instruction which does 
not contain a variant character. 

In the Types 201 and 201-1 processors, the previous contents of the variant register are 
destroyed by the processing of an instruction which contains an address portion. Thus, the only 
instructions which can chain variant characters in these processors are those instructions coded 
without address portions (i.e. , format 3 on page 4-14). 

Chaining is not limited to sequential operations having the same op code. The only con- 
dition that must be met is that an instruction must leave the contents of AAR, BAR, and, if 
required, the variant register such that they satisfy the addressing requirements of the next 
instruction in sequence. 

Toenablethe programmer to chain instructions wherever possible, the description of each 
instruction (see Section 8) includes a table showing the contents of the address registers after the 
instruction has been executed. Also, Appendix C denotes whether each instruction in the machine 
complement can or cannot be chained. 
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5 

EASYCODER 

PROGRAMMING 



INTRODUCTION 

The preparation of Series 200 programs is greatly simplified by Easycoder — a concise, 
easy-to-use programming system. Specifically, Easycoder relieves the programmer of many 
time-consximing duties associated with writing a program in actual machine language. It makes 
it unnecessary, for example, to maintain a careful record of the storage address assigned to each 
instruction. In addition, it allows the programmer to employ meaningful symbolic tags (e. g. , 
TAX, FICA, and TOTAL) to specify data, rather than using absolute memory addresses. In 
situations where a stored program must be relocated or modified, Easycoder can be used to 
perform the required alterations automatically. 

The Easycoder system consists of two basic elements: the Easycoder symbolic language 
and the Easycoder Assembly Program. The Easycoder language is used to write the symbolic 
program (the source program ), while the Assembly Program translates the source program into 
the actual machine -language program (the object program ). 

To prepare a program in Easycoder language, the programmer uses an Easycoder Coding 
Form (see Figure 5-4) and enters each symbolic instruction or definition on a separate line. As 
a general rule, the instructions are written in the order in which they are to be executed. After 
the symbolic program has been written, each line of symbolic coding is punched into a separate 
source program card. These cards are the input data which will be processed by the Easycoder 
Assembly Program. 

The Assembly Program accepts the source program cards and automatically produces a 
corresponding machine -language object program. It converts mnemonic operation codes into 
machine -language codes, assigns absolute storage addresses to instructions and symbolic oper- 
and references, and completely assembles the final program, storing it on punched cards or 
magnetic tape. A secondary output of the Assembly Program is a complete printed summary of 
the symbolic source program and the corresponding machine -language entries. 
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If the programmer finds it necessary to alter the object program after it has been as- 
sembled, he can isolate the affected areas in the source program , enter the required changes, 
and then use the Assembly Program to reassemble a corrected version of the object program. 
Figure 5-1 illustrates the relationship of the source program, the Assembly Program, and the 
object program. 




EASYCODER SYMBOLIC LANGUAGE 

The symbolic language is composed of a set of mnemonic operation codes and a set of rules 
for defining memory areas, addressing operands, and entering constants. The mnemonic opera- 
tion codes are predefined abbreviations for machine -language operation codes and, in general, 
provide an easily remembered description of each instruction. For example, SI is the Easycoder 
mnemonic for the Set Item Mark instruction, and BCC is the mnemonic for the Branch on Charac- 
ter Condition instruction. The set of rules includes special mnemonics for defining work areas 
in the main memory and for defining programmer -specified constants. 



The statements used in writing an Easycoder program can be classified into three groups: 

1. Data formatting statements make it possible to reserve areas and store 
constants without regard to their actual locations in memory. Data format- 
ting statements are completely described in Section 6. 

2. Assembly control statements are used by the programmer to control the as- 
sembly of his program. A complete description of assembly control state- 
ments can be found in Section 7. 

3. Data processing statements are the actual machine instructions to be exe- 
cuted in the object program. Section 8 contains a description of the data 
processing statements employed by the Models 200, 1200, and 2200. 
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EASYCODER ASSEMBLY PROGRAM 

The Easycoder Assembly Program translates the symbolic source program (written on the 
Easycoder Coding Form and subsequently punched into a source program card deck) into machine - 
language entries, placing the resultant object program on either punched cards or magnetic tape. 

In addition to the object program output, the Assembly Program also produces a printed listing con- 
taining the symbolic source program and the corresponding object program entries. (See Figures 5-2 
and 5-3. ) 
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' B ADDRESS ' 
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mark in this location) 
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( Octal Representation of 1250) 



Figure 5-2. Two-Character Address Assembly 
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DIRECT 

ADDRESS 



INDEX 
REGISTER 4 



Figure 5-3. Three -Character Address Assembly 
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Figure 5-2 illustrates how the Assembly Program assembles an object program instruc- 
tion using two-character address assembly. Assume that the tag AMT is assigned to memory 
location 800 and that the tag TOTAL is assigned to memory location 1250. Figure 5-3 shows 
how the Assembly Program assembles an object program instruction using three -character ad- 
dress assembly. Assume that the tags are assigned the same values as in Figure 5-2. 

CODING FORM 

Programs are written on the Easycoder Coding Form (Figure 5-4). This form is composed 
of fixed-format fields for coding such entries as card number, location, and operation code, and 
a variable -format field for operand addresses and comments. The numbers associated with each 
subdivision, or field, on the coding form indicate the card columns into which the characters 
written by the programmer as to be punched. 
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Figure 5-4. Easycoder Coding Form 



CARD NUMBER (Card Columns 1-5) 

This five -character field is divided into three parts: the first two characters are used for 
page numbering, the next two for line numbering, and the last character for insertions. The page 
entry provides the proper sequencing of coding forms. The line number entry is used for the 
sequential numbering of instructions on each coding form. The single -character insertion entry 
permits one or more lines of coding to be inserted between existing lines. For example, to 
insert a line of coding between lines 16 and 17 of page 8, the following coding could be used. 
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TYPE (Card Column 6) 

The programmer can enter lines of descriptive information, called remarks lines, anywhere 
in the source program. Such a line, containing only descriptive data within columns 8 through 80, 
is identified by an asterisk in column 6. Information inserted in this manner appears in the pro- 
gram listing but does not appear as an entry in the object program. 



EASYCODER 

CODING FORM 



PROBLEM - — PROGRAMMER DATE PAGE OF 



CARD 

NUMBER 


T| 


I LOCATION 


OPERATION 
! CODE j 


OPERANDS 




1 2 |3 4l 5 


6 1 


^ 8 , \A 


I5l . , , ,20 


2I. . , . I , . . . I , . , , I . , , . I , I ,62 


63 , 1 . , . , , , , , . 1 , , , ,80 






SPEdl FV 




L .C ONSTANT.S . . . 


L_l.. 1, 1. a .J. j L 1 1 1 . . . 



MARK (Card Column 7) 

This field, used in conjunction with data formatting operations (described in Section 6), 
serves to set up required punctuation. Two sets of punctuation indicators are available: set I 

may be employed with all Easycoder Assembly Systems; set II, however, may only be used with 
the Easycoder C Assembly System. ^ Both punctuation sets are described below. 

Set I, consisting of a blank, an L, and an R, establishes the position of the item mark when 
defining an item (see Table 5-1). Word marking for this first set depends upon the class of in- 
struction, as determined by the contents of the op code field. 



NOTE: When an L is used and the leftmost (high-order) character is auto- 
matically word marked, a record mark will result. 

Table 5-1. Set I Punctuation Indicators 



Coltimn 

1 


. Iti^ Mark Setting 


Contents 


leftmost (Higk»o'r4er)' Chaa?^ct#'a*' 


Rightmost Character 


A 


A 


A 


L 


Item Mark 


A 


R 


A 


Item Mark 



Set II, designed for use with the Easycoder C Assembly System, can be employed in situa- 
tions which warrant unusual punctuation requirements. With this set (listed in Table 5-2), any 
one punctuation indicator controls the complete punctuation setting for the particular instruction 
or constant. However, there is no implicit word mark setting as in the first set. In other words, 
this second set of punctuation is not dependent upon the class of instructions. 

1 

See Section 7 for definitions of the various Easycoder Assembly Systems. 
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Table 5-2. Set II Punctuation Indicators 
(Easycoder C Only) 



Column 

7 


Resultant Punctuation Setting 


Contents 


Leftmost (High-order) Character 


Rightmost (Low- order) Character 
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Word Mark 
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Item Mark 
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Record Mark 


A 


D 


A 


Word Mark 
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Item Mark 
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Item Mark 


Item Mark 
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Word Mark 
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Record Mark 


Word Mark 
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Record Mark 


Item Mark 


T 


Record Mark 


Record Mark 



LOCATION (C ard Columns 8-14) 

The location field can contain a symbolic tag or an absolute memory address, or it can be 
left blank. Symbolic tags provide meaningful symbolic references for storage locations, con- 
stants, and instructions that are referenced elsewhere in the program. All symbolic tags written 
in the location field are assigned absolute addresses during assembly. When an entry is assigned 
a symbolic tag, the contents of the entry can then be referred to by that tag. This means that the 
programmer can refer to data via a symbolic tag and need not be concerned with its actual main 
memory address. 

A symbolic tag is composed of from one to six characters which can be alphabetic (A to Z) 
or numeric (0 to 9); the first character of the tag must be alphabetic . Location field entries are 
normally left- justified; that is, the first character is written in column 8. If a symbolic tag is 
assigned to an instruction, the address assigned to the tag by the Assembly Program will be the 
address of the operation code (the leftmost character in the instruction). K a tag is assigned to 
a constant or a reserved area, the address assigned to the tag will be that of the rightmost 
c^^^^cter in the field. (These address assignment conventions can be reversed by leaving column 
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8 blank and entering the first character of the tag in column 9. In this case, a tag assigned to an 
instruction will refer to the rightmost character of the instruction, and a tag assigned to a con- 
stant or reserved area will refer to the leftmost character in the field. ) 

The programmer may also write an absolute memory address (expressed as a decimal 
number) in the location field. This address will be assigned to the operation code of an instruc- 
tion, or to the rightmost character of a constant or a reserved area. (If the address is written 
starting in column 9, the address assignment conventions are reversed as described above. ) 



EASYCODER 

CODING FORM 



PROBLEM — PROGRAMMER DATE PAGE OF 
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The first instruction shown above moves the contents of the field tagged FICA to the field 
tagged TAX. This instruction can be referred to in the operands field of another symbolic pro- 
gram entry via the tag BEGIN. For instance, the second instruction causes the program to 
branch to the MCW instruction by referring to it via its symbolic tag (BEGIN). In other words, 
the address of the operation code of the MCW instruction is inserted in an object program instruc- 
tion wherever the tag BEGIN appears as an operand in a symbolic program entry. The third in- 
struction defines an alphanumeric constant which can be referred to in the operand field of an- 
other symbolic program entry via the tag DATE. In this case, the tag refers to the address of 
the rightmost character in the constant. 

OPERATION CODE (Card Columns 15-20) 

This six-character field can contain a mnemonic operation code for a machine instruction, 
an assembly program directive, or a data formatting code (see entries below). These entries 
must be left- justified. Machine-language operation codes (in octal notation) may be used instead 
of mnemonic codes. These octal codes are written in columns 19 and 20 of the operation code 
field, and columns 15 to 18 are left blank. 
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OPERANDS (C ard Columns 21-62) 

The operands field is a variable-format field which can contain a series of entries separated 
by commas and terminated by the first blank following any character other than a comma or a 
blank. Column 62 also terminates the operands field. Any punches appearing in columns 63-80 
of any line other than a remarks line (see page 5-5) are ignored and do not even appear in the 
object program listing. ^ 

In general, the operands field contains such entries as the addresses (either symbolic or 
absolute) of the data to be operated upon by a command in the operation code field, literals, ad- 
dress constants, or input/ output information. As explained in the following paragraphs, relative, 
indexed, and indirect addressing can be used in conjunction with absolute or symbolic addresses. 

The first sample instruction causes the contents of the field whose rightmost character is 
stored in memory location 50 to be added algebraically to the contents of the field designated by 
the tag TOTAL. 

The second instruction tests the indicator specified by variant character 3 and branches to 
the address tagged EQUAL if the indicator is on. 



EASYCODER 
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The third line of coding above shows an instruction in which the B address is indexed. The 
instruction causes the contents of field tagged TOTAL to be placed in the field designated by the 
tag TMP as modified by the contents of index register 3. 



^The Easycoder C Assembly Program (see Section 7) interprets punches in columns 63-80 as 
comments and prints these comments in the program listing. 
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The fourth line of coding shows relative addressing and indexing being performed on the A 
address. The instruction causes the address seven before that tagged TOTAL to be modified by 
the contents of index register 6. The resultant address specifies a field whose contents are then 
placed in the field tagged GROSS. Assuming that TOTAL corresponds to memory location 540 and 
index register 6 contains a value of 80, the resultant A address of this instruction would be 613. 

The last line of coding above illustrates an instruction with indirect addressing on the B 
address. The contents of the field tagged AMT are added algebraically to the contents of the 
field whose address is stored in the field tagged SUM-2. 



ADDITIONAL CODING RULES 

1. Comments and remarks can appear on any line following the last entry on that 
line and separated from it by a blank space. These notes will be printed on 
the program listing but will not be assembled as object program entries. As 
mentioned previously, any line of coding containing only comments must be 
designated by an asterisk (’!<) in column 6. 

2. Any number of blank spaces may be used between the comma which terminates 
the A operand and the first character of the B operand. Similarly, any number 
of spaces may be used between the comma that terminates the B operand and a 
variant character. 



ADDRESS CODES 

Several types of address codes are valid in the operands field of an Easycoder statement. 
These codes are defined and illustrated below. 

ABSOLUTE 

The actual address of a character position in the main memory can be represented as a 
decimal number; leading zeros can be omitted. The sample instruction causes the contents of 
the field whose rightmost character location is 32 to be moved to the field whose rightmost 
character location is 4000. 
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SYMBOLIC 

A symbolic address, or tag, can be used in the operands field only if it appears in the lo- 
cation field elsewhere in the symbolic program. In effect, a tag must be defined (by writing it 
in the location field of a symbolic entry) in order for it to be used as an operand address. 
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The instruction shown above can be referred to elsewhere in the program via its tag 
(TOTAL). It should be noted, however, that this instruction is a valid statement only if the 
symbolic addresses FICA and TOTAX have been defined in the location field elsewhere in the 
source program. 



SELF REFERENCE 

It is sometimes convenient for an instruction to refer to itself. A self reference is indicated 
by an asterisk in the operands field of a source program instruction. The Assembly Program 
automatically replaces the asterisk with the address of the leftmost character of the instruction 
in which it appears. Address modification and relative addressing can be performed on asterisk 

operands. 
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15, 20 
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63, , 1 , , , , I ^ 






“ 




M,CW 


^^ + 4 W.ORK . , 


■ ■ 1 ^ 1 — 1 i 














_! 1 1 1 L_i . 1 1-_I 1 1 1 




' 






WCW 


W.ORJl ^ . . , . . , . . , . 


■ ll.il ■ 1 . . . ■ 1 I l__i l_ 


- M 












. ■ 1 . L j, J L i— l-^— I 1— ^ L,- 1 t 














■ , 1 ■ ■ 1 ■ i L i— . 1 ■ ■ . 1 


— -4— -J — 


\— 




1 ‘ ‘ ‘ ‘ ‘ 


1 ‘ ‘ ‘ ‘ 







In the first sample entry above, the notation >:<+4 addresses the rightmost character of the 
instruction in which it appears (assuming that two-character address assembly has been speci- 
fied). Since the function of this instruction is to move the field specified by the A address to that 
specified by the B address, the instruction itself will be moved to the field tagged WORK. 

In the second entry, the notation refers to the rightmost character of the instruction 

stored immediately to the right of the MCW instruction (assuming that two-character address 
assembly has been specified). The instruction following the MCW instruction will be moved to 
the field tagged WORK when the MCW instruction is executed. 



RELATIVE 

Relative addressing, or address arithmetic as it is frequently called, can be used with all 
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absolute addresses, symbolic addresses, and the self-reference symbol (*) (these three types of 
address codes are referred to as addressing "elements"). By using relative addressing, the 
programmer can refer to a source program entry that is stored a specified number of locations 
away from a particular address. A relative address is specified by appending one or more ad- 
dress modifiers, each consisting of a sign and an addressing element, to another addressing ele- 
ment. The address modifier designates a memory location relative to the location specified by 
the baste addressing element. For example, the instruction below causes the contents of the field 
100 characters beyond the field tagged INT to be added algebraically to the contents of the field 
10 characters before the sum of the addresses defined by the tags AMTPD and ERROR 



EASYCODER 



PROBLEM 



CODING FORM 



PROGRAMMER . 



PAGE OF- 




The number of symbolic tags required to write a program can be greatly reduced by the 
use of relative addressing. The programmer decides how many and which fields in a program 
to tag and which to reference by relative addressing. 



A certain amount of caution is required in the use of relative addressing. First of all 
relative addresses are not automatically corrected as a result of subsequent insertions or dlle- 
txons m the source program. The programmer must remember to adjust manually the address 
modtfxers affected by such changes. Secondly, if relative addressing is used to refer to an 
operand address in another instruction, care must be taken to insure that the address is refer- 
enced by xts rightmost character. For example, the A address of the instruction shown below 
could be referred to elsewhere in the program as INST+2. INST«. or INST+4. depending 
whether two-, three-, or four-character address assembly were specified. 

EASYCODER 



on 



PROBLEM . 



COOING FORM 



CARO 

NUMBER 

I I . 2 I 3 4T^ 



tt 



LOCATION 



^n.s,t 



OPERATION 

CODE 



_ PROGRAMMER . 



- DATE . 



. PAGE . 



OPERANDS 



TOTAL, 



BLANK 



There are two conditions for which a blank operand field is valid: 

InsVnctioZT '"• No Operation 

JonteTs'of »y the 

contents of thp. R register AAR), the B operand is specified by the 

contents ot the B-address register (BAR). 
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If either or both operand addresses are to be supplied by other instructions (as illustrated 
below in the description of address literals), the affected operands should be represented by 
zeros; they should, not be left blank. 



LIT E RA LS ^ 

The purpose of a literal is to allow the programmer to write in the operands field of a 
symbolic program statement the actual data (as opposed to the address of the field containing 
the data) to be operated on by an instruction. All literals, except binary literals, can be coded 
with a maximum length of 40 characters. A binary literal can be coded with a maximum length 

of six characters. 



The Assembly Program automatically assigns a storage field for each literal and inserts 
its address (i. e. . the address of its rightmost character) in the operands field of the instruction 
in which it appears. In effect, for every literal appearing in the source program, the Assembly 
Program generates a constant containing the value of the literal, with a word mark in the left- 

most character position. 

note- It the constant generated from a literal occupies from one to five storage 
locations, it is assigned a storage address only once in the program, 
regardless of the number of times the literal appears in the source pro- 
gram. A constant that exceeds five characters is assigned a storage ad- 
Less each time the corresponding literal appears in the source program. 

The latter condition can be avoided by using a DCW statement (see page 
6-2) whenever a long literal is to be used more than once in the source 

program. 



Dec imal Literals 

Decimal literals are specified by writing a plus or minus sign followed by the value of t e 
literal. When the literal is assigned to a storage field, the Assembly Program places the sign 
in the zone bits of the units position of the resulting constant. Unsigned decimal values can be 

coded as alphanumeric literals. 



EASYCODER 



CODING FORM 



PROGRAMMER 



PROBLEM 




The statement above illustrates the use of a decimal literal. The instruction causes the 
value 24 to be subtracted from the contents of the field tagged ACCUM. 



1 Available only with Easycoder B and C. 
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Binary Literals 

A binary literal is represented as a decimal entry in the operands field of a symbolic in- 
struction. The Assembly Program automatically converts the decimal entry into a binary value 
and stores it (right- justified) in the storage field. The programmer must specify the number 
of six-bit characters (not to exceed six) used to store this value. 

A binary literal is coded by writing a # sign, followed by a number from 1 to 6 which 
specifies how many six-bit characters should be used to store the resulting binary value, 
followed by the letter B, followed by the decimal representation of the desired binary literal. 

NOTE: If the decimal representation of the binary literal is preceded by a minus 

sign, the Assembly Program will store the binary literal in twos-comple- 
ment form. 



The first instruction below causes the binary equivalent of 50 (expressed as a continuous 
12-bit binary value) to be added to the contents of the field tagged BEGIN+2. The second in- 
struction has been included to illustrate how a binary literal can be used in address modification. 
In effect, the first instruction modifies the A address of the second instruction by a value of +50. 
The third instruction causes the binary equivalent of 2688 (expressed as an 18-bit binary value) 
to be moved to the field tagged IND7. 



EASYCODER 
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PROBLEM PROGRAMMER nATF P/IRF OF 


CARD 
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T 
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OPERATION 

CODE 


OPERANDS 




1 .2 |3 .41 5 


6 


7 


8. . 1 . . .14 


15^ 20 


. . 1 . . . . 1 . . , . 1 . 1 . , 1 . , , , 1 , , , , , . , 1 ,62 




-4^ 






1 . . . 




<T2.B5.gi,,.6g.G.i,N.+.2. . . , . . , . 




■ 1 






B.E.S.hN, , 


MCW 


LT.E.MAy.T,Q.TAL. . , . , 




. 1 






...4 > 1 .. . ■ 


1 . . . . 






-J ■! 






. t . . ■ 


MCW 


»3B.a6, ae., iN,D7. , . , , . , 






_ 


_ 


■ . 1 ■ ■ ■ 


l . . . . 


-■ — ' — ' — ' — 1 — ' — ' — ■ — ^ j — * — >— ■ — 1 — 1 — . — . — 1 — . — 1 1 1 1 . 1 , , , 1 , 


. i J i . 1 i 1 i X . ■ 1 ^ ■ ■ 



Octal Literals 

Octal literals are coded in octal notation (see Appendix A). The programmer must specify 
the number of six-bit characters (not to exceed 20) required to store an octal literal. 

NOTE: Since every octal digit can be represented as three bits, each six-bit 

character used to store an octal literal contains two octal digits. For 
example, an octal literal composed of eight octal digits can be stored 
in a four-character field. 



An octal literal is coded in the same format as a binary literal except that the letter B used 
in the binary literal is replaced by the letter C. The constant stored by the Assembly Program 
is always left-justified in the storage field. 
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EASYCODER 

COOING FORM 



PROBLEM 
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DATE 



PAGE OF 
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OPERATION 

CODE 


OPERANDS 




1 2 |3 4l S 
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7 


8. . I . . ,J4 


>5| . . . 20 




63^ 1 ]. 1 1 1 1 1 1 1 1 1 1 1 1 i®0 







_ 


...... 




»3.C.777,7,,MAS.K . . , . , , 


_l... L- J J J 1. ■ . 1 .1 L _L._X J. 



The A operand in the above statement is a four-digit octal literal. The Assembly Program 
will store it left- justified in a three-character field, as 777700. 

Alphanumeric L iterals 

An alphanumeric literal can contain blanks, decimal, alphabetic, and special characters 
(excluding the @ symbol). It is specified by writing the 0) symbol before and after the value of 
the literal. If the <s> symbol is required within a literal, a DCW statement (see page 6-2) should 
be used. 
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J . ■ ■ ■ 1 ■ . ■ ■ 1 . . . . 1 . . ■ ■ 1 ■ . . . J , . . . 


1 ,62 
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1 1 , 1 . . { i 




- 


- 


. . 1 . . . 




^ACCOUNTS ,P,AYA8,LE,.a./,l,0,/,6,5,®.,,PRi,NT 


1 ■ 1,-J 1 -■ -L 1 . 



The statement above illustrates the use of an alphanumeric literal. The instruction causes 
the information contained within the @ symbols to be moved to the field tagged PRINT. 

Area Defining .L iterals 

An area defining literal may be used to define and reserve a working area in memory with- 
out using a separate data formatting instruction. The address which defines the area is written 
as a symbolic tag. The size of the area to which the literal address refers is specified as a 
decimal value following the literal address and separated from it by a # symbol. 
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In the instruction above, the entry TEMP#5 causes the Assembly Program to reserve a 
blank five-character area with a word mark set in the leftmost character position. The address 
of the rightmost character in this area is assigned to the tag TEMP. Therefore, TEMP can be 
used as a symbolic address elsewhere in the source program, because both the tag and size of 
the area to which it refers are defined. The sample instruction causes the contents of the field 
tagged WAGE to be moved to the field tagged TEMP. 
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Address Literals 

An address literal enables the programmer to specify a symbolic address in the operands 
field of an instruction such that the Assembly Program will use the address as an operand. A 
symbolic address can be used as an address literal only if it is defined elsewhere in the symbolic 
program. The tag used as an address literal must be preceded by a plus or a minus sign. 



An address literal (+AMT) is used in the first sample entry below. Assume that AMT has 
been defined elsewhere in the program and has been assigned an absolute address of 800. The 
absolute address of AMT, as opposed to the contents of the field tagged AMT, replaces the ad- 
dress literal. The first instruction below causes the value 800 (the absolute address assigned 
to AMT) to be moved to an address two greater than the location tagged MODIF. The second 
entry shows how an operand address can be supplied by another instruction. Specifically, the 
absolute address assigned to the tag AMT is supplied as the A address of the instruction tagged 
MODIF. This instruction causes the contents of the field tagged AMT (i. e. , the field whose 
rightmost character is stored in location 800) to be added algebraically to the contents of the 
field tagged TOTAL. 
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VARIANT CHARACTER 

A variant character can be expressed as one alphanumeric character, as two octal digits, 
or as a symbolic tag. ^ It is written following the operand entries and separated from the last 
entry by a comma. Octal representation of valid variant characters are listed in Appendix B. 
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^ A symbolic tag, composed of at least two characters, may be used to represent (1) a variant 
character, or (2) a group of input/ output control characters. The number of I/O control 
characters that may be represented varies from one to six (using either the Easycoder A or 
B Assembly System) or from one to four (using the Easycoder C Assembly System). The 
symbolic tag must be defined before it is used in the input/ output instruction; the Control 
Equals statement (CEQU) is generally used for this purpose (see page 7-11). 
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The first instruction, above tests an indicator specified by the variant character. If the 
indicator is on, the instruction causes the program to branch to the address tagged OFLOW. 

As might be expected, the octal digits 50 represent the overflow indicator. The second instruc- 
tion causes the single character at the location tagged SUM to be examined for a particular bit 
configuration as specified by the variant. In this case the variant 06 specifies that the charac- 
ter should be examined for a negative sign. If the desired bit configuration is present, the pro- 
gram branches to the address tagged NEG. 

INPUT/ OUTPUT CONTROL CHARACTERS 

Input/ output control characters can be used only in conjunction with input/ output instruc- 
tions (see Section 8). One or more of these characters may be written following the A-address 
entry in an input/ output instruction, each preceded by a comma. Input/ output control characters 
may be coded as single aplhanumeric characters, as pairs of octal digits, or as symbolic tags. ^ 

ADDRESS MODIFICATION CODES 

In a system equipped with the Advanced Programming Instructions (Feature 010 or Oil), 
two address modification codes are valid in the operands field of a source program statement: 
indexed and indirect. These codes allow the modification of operand addresses without altering 
the instructions in which the addresses appear. This is in direct contrast to the permanent 
alteration of an instruction that results from using a binary arithmetic instruction to modify 
either or both operand addresses. 

INDEXED 

Indexed addressing is performed by appending to the address being modified a code to 
indicate which of the index registers is to be used. The code consists of a plus sign followed 
by an X and the decimal number of the desired index register (see Tables 4-2 and 4-3, pages 
4-11 and 4-13, respectively). 

If an index register is to be specified in the operands field of an instruction for other than 
indexing purposes, it is referred to by its absolute address rather than its symbolic address. 

For instance, absolute address 24 is used instead of the corresponding symbolic address X6. 



^A symbolic tag, composed of at least two characters, may be used to represent (1) a veiriant 
character, or (2) a group of input/ output control characters. The number of I/O control 
characters that may be represented varies from one to six (using either the Easycoder A or 
B Assembly System) or from one to four (using the Easycoder C Assembly System). The 
symbolic tag must be defined before it is used in the input/ output instruction; the Control 
Equals statement (CEQU) is generally used for this purpose (see page 7-11). 
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However, the programmer may use the symbolic address if he equates it to the absolute address 
using an EQU statement (see page 7-10). 
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The first instruction above causes the contents of the field designated by the tag DATA as 
modified by the contents of index register 6 to be compared to the contents of the field tagged 
POS. The second instruction causes the contents of the field tagged STORE to be added (in 
binary) to the contents of index register 12. The use of the symbolic designation X12 implies 
that an EQU statement was used to equate it to the absolute address of index register 12. The 
third instruction illustrates how an indexed address can be coded to generate an effective ad- 
dress which is less than the value stored in the specified index register. The zero is used be- 
cause an operand address cannot be introduced with a plus or a minus sign. Thus, the effective 
A address of the MCW instruction will be a value six less than that stored in index register one 
(i. e. , if index register one contains 126, the effective A address is 120). 

Three- or four-character address assembly must be specified (see ADMODE, page 7-9 ) 
whenever indexed addressing is to be performed. When the Assembly Program translates an 
indexed address into a machine-language entry (see Figures 5-5 and 5-6), the translated index 
register designator is automatically inserted into the address modifier bits of the assembled 
address. 




Figure 5-5. Assembly of Indexed Address in Three-Character Addressing Mode 
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ALWAYS ZERO (SEE PAGE 4-8) 
INDEX 18- BIT REPRESENTATION 

REGISTER [- OF ADDRESS ASSIGNED 

DESIGNATOR | TO THE TAG AMNT 



|0 I lOOjO^XXXXXXXXXXXXXXXXXX 



B ADDRESS OF 
ASSEMBLED INSTRUCTION 



Figure 5-6. Assembly of Indexed Address in Four-Character Addressing Mode 



INDIRECT 

An indirect address is specified by enclosing the address (either symbolic or absolute) in 
parentheses. For example, in the sample instruction below, the parentheses around the tag 
DATA indicate to the Assembly Program that DATA refers to the leftmost character of a field 
containing another address. This second address may be a direct, an indexed, or another in- 
direct address. 
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If it is direct or indexed, it specifies the rightmost character of a data field. If it is indirect, 
it specifies the leftmost character of a field containing another address. 



Three- or four-character address assembly must be specified whenever indirect addressing 
is to be used. When the Assembly Program translates an indirect address into a machine- 
language entry (see Figures 5-7 and 5-8), an octal value of 7 (three-character mode) or 20 (four- 
character mode) is automatically inserted into the address modifier bits of the assembled address. 




Figure 5-7. Assembly of Indirect Address in Three- Character Addressing Mode 
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INDICATES 

INDIRECT 

ADDRESS 




ALWAYS ZERO (SEE PAGE 4-8) 

18-BIT REPRESENTATION 
I — OF ADDRESS ASSIGNED 
TO THE TAG TEMP 



100 0 0101 XX XX XX XX XX XX XXX XXX 



B ADDRESS OF 
ASSEMBLED INSTRUCTION 



Figure 5-8. Assembly of Indirect Address in Four-Character Addressing Mode 
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DATA 

FORMATTING 

STATEMENTS 



INTRODUCTION 

A value or quantity which must remain fixed or which must be used repeatedly in a program 
is called a constant . A work area is an area in memory which is reserved for input data, cu- 
mulative processing, or output data. By employing data formatting statements, constants can 
be stored and work areas can be reserved without regard to their actual locations in memory. 

For instance, the programmer can use a data formatting statement to reserve an 80 -character 
card input area and assign it a symbolic address such as CARDIN, without knowing the actual 
address of the field. Similarly, a data formatting statement makes it possible to store a con- 
stant, such as 2000, and to refer to it by a symbolic tag, such as CONS, without regard to the 
address at which the constant is stored. Table 6-1 lists the five data formatting statements used 
with Easycoder symbolic language. 

Table 6-1. Data Formatting Statements 



Mnemonic 
Operation Code 


Function 


DCW 


Define Constant with Word Mark 


DC 


Define Constant without Word Mark 


RESV 


Reserve Area 


DSA 


Define Symbol Address 


DA 


Define Area”^ 


'■'NOTE: The Define Area statement may be employed only 
with the Easycoder B and C Assembly Systems 
(see page 7-1). 



Although data formatting statements are coded in the same format as most symbolic ma- 
chine instructions (data processing statements), they are not treated as instructions by the As- 
sembly Program. Instead they are treated as definitions which cause the Assembly Program to 
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perform certain activities but which are not executed during a program run. Since data format- 
ting statements are not executed during a program run, they should not be written in the body 
of the symbolic program. 



Define Constant with Word Mark - DCW 

By use of the DCW statement, a constant can be automatically stored in a field reserved 
by the Assembly Program. In storing the constant, the Assembly Program automLatically sets 
a word mark in the leftmost character position of the storage field. Item marking may be 
specified as in Table 5-1 (page 5-5). An L in column 7 thus results in a record mark with a 
DCW statement. 

NOTE: If the Easycoder C Assembly System is being used and if unusual high- 
and low-order punctuation is required, the programmer may use a set 
II punctuation indicator as shown in Table 5-2 (page 5-6). 

The constant can be assigned a tag. If the tag is left -justified in the location field, it is 
assigned to the address of the rightmost character of the constant. If the tag is indented one 
column, it is assigned to the address of the leftmost character of the constant. 

NUMERIC CONSTANTS 

Numeric constants may take any one of three forms: binary, octal, or decimal. Octal 
and decimal constants can be coded with a maximum length of 40 characters, while the coding 
associated with a binary constant is limited to a maximum of six characters. 



Decimal Constants 

Signed decimal constants are specified by writing a plus or a minus sign in colunnn 21 
followed by the value of the constant. When the constant is assigned to a storage field, the As 
sembly Program places the sign in the zone bits of the rightmost character of the constant. ^ 
Unsigned decimal constants are written in the operands field beginning at column 21. 
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The first statement above shows the decimal value of +22 defined as a decimal constant. 
The second statement defines the unsigned decimal value 45 as a constant which can be referred 
to via the tag HAL. 

^See the description of sign codes beginning on page 8-9. 



6-2 







DEFINE CONSTANT WITH WORD MARK - DCW 



Binary Constants 

A binary constant is actually written as a decimal entry which is then automatically con- 
verted to a binary value by the Assembly Program. The binary value is stored (right-justified) 
in the constant field. 

To code a binary constant the programmer writes the following: (1) a # sign (in column 

21); (2) a number from 1 to 6 which designates the number of six-bit characters needed to store 
the resulting binary value; (3) the letter B; (4) the decimal representation of the desired binary 
constant. Note that if the decimal representation of the binary constant is preceded by a minus 
sign, the Assembly Program stores the binary constant in twos -complement form. 
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The statement above shows the binary equivalent of 50 defined as a binary constant to be 
stored in two consecutive character locations. 

Octal Constants 

Octal constants are coded in octal notation (see Appendix A). To code an octal constant 
the programmer writes the following: (1) a # sign (in column 21); (2) a number (not to exceed 20) 

which specifies the number of six-bit characters required to store the octal constant;^ (3) the 
letter C; (4) the constant value. Note that the value stored by the Assembly Program is always 
left-justified in the storage field. 



EASYCODER 

COOING FORM 



PROBLEM — - PROGRAMMER DATE PAGE OF 



CARD 

NUMBER 


1 


t 


LOCATION 


OPERATION 

CODE 


OPERANDS 




1 2 |3 4l 5 


6 


7 


8 , 14 


15, ,20 


21, . . . 1 , , . , 1 . . . , 1 , 1 1 , 1 . , 1 . . . . 1 , , , 1 .68 


63 , , , , . ... .00 


Tlt 






OCT, 7 


D,C.W . . 


^2C7777 . . I . . , . , , 






In the statement above, the octal value of 7777 is shown defined as an octal constant to be 
stored in two consecutive character locations. 



^Recall that an octal digit can be represented as three bits; thus each six-bit character used to 
store an octal constant contains two octal digits. For example, an octal constant composed of 
six octal digits can be stored in a three -character field. 
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ALPHANUMERIC CONSTANTS 

Alphanumeric constants may be coded in one of three ways: 

1. Constants (including special symbols and blanks) may be written with the 
constant value enclosed in ©symbols (see the first entry below). 

2. If the @ symbol is required in the constant, this constant is enclosed in 

any unused character other than blank, +, #, or the digits 0 through 9 

(see the second entry below). 

3. A number sign (#) is followed by a number from 1 through 40 which speci- 
fies the number of alphanumeric characters contained in the constant; 
this number is, in turn, followed by the letter A and the alphanumeric 
constant (see the third entry below). ^ 



EASYCODER 

COOING FORM 



PROBLEM PROGRAMMER DATE PAGE OF. 



CARD 

NUMBER 


L 


LOCATION 


OPERATION 

CODE 


OPERANDS 




1 .2 |3 4| 5 


6 


^ ■ 1 . . 


I5| . , . 20 




, 1 . , , . 1 . , . . 1 , , . .80 


— . 1 




COST 




®i 2 ,j. 2 , 8 ... 6 se_ , 




1 

- ^ 1 ■ 1- 




L_. u j 


1 






, 1 1 




rate 


DCW 


%<§>SI X.DOLL A,RSy HR.Vo , 








. . 1 , . . 


i ... . 


1 1 1 1 1 I 1 1 




1 1 
.1.1- 


-- 


DATE 


ocw 


ff4A19A5. . 


. 1 . . 1 . 1 , . . . 1 . . . . 



BLANK CONSTANTS 

The DCW statement may be used to reserve a field of blanks with a word mark in the left- 
most character position of the field. The programmer writes a # symbol (in column 21) followed 
by a decimal value (from 1 to 40) which indicates the number of blank storage positions desired. 



EASYCODER 

CODING FORM 



PROBLEM PROGRAMMER DATE PAGE OF. 



CARD 

NUMBER 


T 


m 

R 

K 


LOCATION 


OPERATION 

CODE 


OPERANDS 




■Ptfinn 


□ 


a 


8. . 1 . . .14 






1 1 . . . . 1 . , 1 1 80 


1 

1 ■ 1 


H 




blank 




. 




1 1 















The DCW statement above defines a 21 -character blank field. The address assigned to this 
field by the Assembly Program will be inserted in an object program instruction whenever the 
tag BLANK appears in another symbolic program entry. 



This third method of coding alphanumeric constants is applicable only when using the Easycoder 
C Assembly System (see page 7-1). 
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I Define Constant - DC 

The DC statement is functionally the same as the DCW statement, the only exception being 

the absence of automatic word marking. This statement may thus be used in place of the DCW 

statement if a constant is to be stored without a word mark in its leftmost character position. 

The programmer , however, may still specify item marking as shown in Table 5-1 (page 5-5). 

NOTE: If the Easycoder C Assembly System is being used and if unusual high- 
and low-order punctuation is required, the programmer may use a set 
II punctuation indicator as shown in Table 5-2 (page 5-6). 



Reserve Area - RESV 

Use of the RESV statement enables the programmer to reserve an area of memory. Un- 
like the DC and DCW statements (which cause data to be loaded into an area reserved by the 
Assembly Program), the RESV statement does not alter the contents of the area defined when 
used with the Easycoder A or B Assembly System. Rather, it simply sets aside a storage area 
to which the programmer can refer by a symbolic tag. If it is desired to clear the reserved 
area to zeros in either of the above systems, the CLEAR statement must be employed (see 
page 7-15). The number of characters in the reserved area must be specified in the operands 
field of the RESV statement. A previously defined tag may be written in the location field. 

When used with the Easycoder C Assembly System., the RESV statement can not only 
reserve a specified area but can also load that area with a particular character. The character 
to be loaded into each location of the reserved area is coded in column 20 immediately following 
a comma and the mnemonic code. If the mnemonic RESV is followed only by a comma, the 
reserved area is cleared to blanks. 

NOTE: There is no automatic word marking for the reserved area. However, 

a punctuation indicator from set I may be placed in column 7 (see page 
5-5). In addition, if the Easycoder C Assembly System is being used 
and if unusual high- and low-order punctuation is required, the pro- 
grammer may use a set II punctuation indicator as shown in Table 5-2 
(page 5-6). 



EASYCODER 

CODING FORM 



PROBLEM PROGRAMMER DATE PAGE OF 



CARD 

NUMBER 




55 


LOCATION 


OPERATION 

CODE 


OPERANDS 




■MEWH 


Q 


□ 


8. 1 . . .14 






63, , 1 . , , 




1 


1 


S.T.OR.E. 




30 . 






1 


1 


3Q0SM 


RESV,05> 


S0 




1 : 




r 











The first statement above reserves 30 consecutive character positions that can be addressed 
via the tag STORE. Note that by referring to the reserved area via a symbolic tag, the 



6-5 








SECTION 6. DATA FORMATTING STATEMENTS 



programmer need not know its actual location in memory. The second RESV statement, as- 
sembled by Easycoder C, reserves 80 consecutive locations and clears the reserved area 
to zeros. 



I Define Symbol Address - PSA 

The DSA statement can be used to store one or two addresses, or two addresses and a 
variant character, as a constant. Any valid address can be stored as a constant; the length of 
each address is determined by the current addressing mode (each address will be two, three, 
or four characters long). 

An item mark may be specified as shown in punctuation set I, page 5-5. In addition, the 
DSA statement automatically places a word mark in the leftmost character position of the con- 
stant (thus an L in column 7 results in a record mark in this position). 

NOTE: If the Easycoder C Assembly System is being used and if unusual high- 
and low-order punctuation is required, the programmer may use a set 
II punctuation indicator as shown in Table 5-2 (page 5-6). 



EASYCODER 

CODING FORM 



PROBLEM PROGRAMMER DATE PAGE OF. 



CARO 

NUMBER 


T 

£ 


1 


LOCATION 


OPERATION 

CODE 


OPERANDS 




1 2 |3 4l 5 


6 


7\ 


1 , . .I** 


I5i . , . .20 




, I . , , , ,00 


^4- 






CODE 


QSA 1 . 


lXEM-5. , . . . 




1 j 
















- 


- 


STAR 


D3A 


■ 


4 i . 1 ■ -■ - ■ 1 



The first statement above permits the address of the field five characters before the field 
tagged ITEM to be referred to in the program by the tag CODE. 

The second statement allows the stored constant consisting of the address assigned to ARG, 
the address assigned to the self -reference indicator and the variant character A (i. e. , octal 
21) to be referred to by the tag STAR. 



Define Area - DA^ | 

A specified area within the main memory can be defined and reserved by using the DA 
statement. In addition to defining an area, the DA statement can also define fields and subfields 
within the reserved area. This statement can also define two or more contiguous areas if these 



The Define Area statement may be employed only with the Easycoder B or C Assembly System. 
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areas are identical in format. In other words, the programmer uses a DA statement to provide 
the Assembly Program with the following basic information: 

1. The number (n) and size (s) of the reserved area(s). 

Z. The index register (Xm) to be associated with each reference to a field or 
subfield within the reserved area(s) (optional). 

3. The character R which will place a record mark one position to the right 
of the rightmost reserved area (optional). 

A DA statement consists of a heading line which defines an area(s), plus one or more sub- 
sequent lines of coding which defines the fields and subfields within the area(s). The heading 
line can contain a symbolic tag in the location field. If this tag begins in column 8, it refers to 
the rightmost location of the entire area, exclusive of the record mark (if present); if the tag 
starts in column 9, it refers to the leftmost location of the entire area. 

The operands field in the heading line has the following format: 



21 




nxs, Xm, R 



If a single 80-character area is to be defined, the value of the nxs is 1x80. If four identical 80- 
character areas are to be defined, the value of nxs is 4x80. 

The DA statement can be indexed by writing an index register designator (from XI through 
XI 5)^ following the area definition. All references to the fields and subfields defined in the DA 
statement will be automatically indexed by the specified index register, but references to the 
tag assigned to the entire area will not be indexed. For example, the statement on the next page 
indicates that all references to the fields and subfields in the 1 1 3 -character area tagged BUFFER 
will be indexed by the index register X2; references to the tag BUFFER, however, will not be 
indexed. 

Note that the area definition nxs does not include an allowance for the character position 
containing the record mark, although this position (if any) is also reserved. For example 4x80 
will cause 320 character positions to be reserved. If a record mark is placed one position to 
the right of the last area, a total of 321 character positions is reserved. 



^Index registers 1 through 6 are used with Easycoder B, while index registers 1 through 15 can 
be used with Easycoder C. 
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The index register applied to a field or subfield can be changed from that specified in the 
DA statement by designating a different register in the operands field of an instruction which 
references the field or subfield. The effect of indexing on a field or subfield can be cancelled by 
writing XO as the index register designator in the references in which indexing is not wanted. 



As stated above, the heading line may be followed by one or more lines of coding which 
define fields and subfields within the reserved area(s). As many of these lines as necessary 
may be used, and these fields and subfields may be defined in any order desired. Positions 
within each reserved area are numbered sequentially from left to right, starting with one. The 
coding lines which define fields and subfields must have blank op code fields; each such line 
may contain a symbolic tag in the location field, if desired. 



Fields and subfields are specified as follows: 

Fields: The lowest and highest positions of the field are written in that order 

in the operands field, separated by a comma. (If a one -character 
field is desired, its position number must be written twice in the 
operands field, separated by a comma. ) A word mark is automati- 
cally placed in the leftmost position of the field in memory. Item 
marks maybe specified as shown in Table 5-1 (page 5-5). 

Subfields: For a subfield, only the rightmost position is specified. Word 
marks are not set; however, item marks may be specified as 
shown in Table 5-1 (page 5-5). 

NOTE: The list of punctuation indicators specified in set II (page 5-6) may not 
be used with DA statements. 



The Assembly Program does not normally clear the defined area. However, the program- 
mer has the option of clearing the area to a specified character by placing a comma and the 
desired character after the mnemonic code DA in the op code field. The presence of only a 
comma after the op code implies that the area will be cleared to blanks. When the defined area 
is cleared, all punctuation is also cleared before setting the "field" punctuation. 



The sample coding below illustrates what a DA statement might look like. 



EASYCODER 

COOING FORM 



PROBLEM PROGRAMMER DATE PAGE OF 





CARD 

NUMBER 




1 


LOCATION 


OPERATION 

CODE 


OPERANDS 






1 2 1 3 4l 5 


6 


7 


0 1 . .14 


'5| . , 20 




63. , I . ,80 


t 


mm 


1 


1 


BUFFER 




4-X.28.j,X2...R , 




2 




1 


1 


NAfAE 


gsin 






3 




1 


1 


DATE 






. , 1 . . . , 1 . . . 1 . . 


4 


mKM 


1 


1 


AGE, 








5 








YEAR 


■BB 






6 




1 


1 


I^OMTH 








7 




1 


1 














■ 


■ 
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The heading line specifies the following information: 

1. Four consecutive, identical areas, each 28 characters long, will be 
reserved. 

2. The tags NAME, DATE, AGE, YEAR, and MONTH, when referred to 
in symbolic instructions, will be indexed by index register two. 

3. A record mark will be set in the rightmost character position of the 
entire 1 1 3 -character reserved area. 

4. The entire 113-character area can be referred to via the tag BUFFER. 

(This tag refers to the leftmost position of the area because it is in- 
dented. It is not automatically indexed by index register two. ) 

Lines two, three, and four define fields. Word marks will be set in positions 1, 21, and 23 in 

each of the four identical areas. Lines five and six define subfields: position 28 indicates the 

year within the date, while position 26 indicates the month within the date. 
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7 

ASSEMBLY 

CONTROL 

STATEMENTS 



INTRODUCTION 

Assembly control statements provide programmer control over the assembly of the source 
program. These statements resemble data formatting statements in that they are treated as 
definitions. They control such functions as the addressing mode to be used in assembling speci- 
fied instructions, the assignment of absolute locations to symbolic tags, etc. Used only during 
the assembly process, assembly control statements are never executed as instructions in the 
object program. The precise function of each assembly control statement depends upon the as- 
sembly system employed. 

A number of assembly systems are available to the Series 200 user. These systems 
include: 

EASYCODER A: Part of the SERIES 200 /BASIC PROGRAMMING SYSTEM. 

Easycoder A operates in a system having a minimum main 
memory size of 4,096 characters. (Additional memory, 
however, may be used to advantage. ) 

NOTE: A counterpart of Easycoder A — Easycoder A (P) - 

— is available for use in a paper tape environ- 
ment. The main memory requirements are 
identical to those of Easycoder A. 

EASYCODER B: Also part of the SERIES 200 /BASIC PROGRAMMING 

SYSTEM. Easycoder B operates in a system having a 
minimum main memory size of 8, 192 characters. (Addi- 
tional memory may be used to advantage, however. ) 

EASYCODER C: Part of the SERIES 200 /OPERATING SYSTEM — MOD 1. 

Easycoder C operates in a system having a minimum of 
12, 288 characters of main memory. (Additional memory, 
however, may be used to advantage. ) 

A summary of the assenably control statencients available with the Easycoder A, B, and C 
Assembly Systems, together with the page where each statement is defined, may be found in 
Table 7-1. In addition, the heading of each statement in this section includes a table which indi- 
cates (by shading) the assembly systems that may use that particular statenaent. 
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Table 7-1. Assembly Control Statements 



Easycoder A 


Easycoder B 


I Easycoder C 


Assembly Control 
Statements 


Page 

Ref. 


Assembly Control 
Statements 


Page 

Ref. 


Assembly Control 
Statements 


Page 

Ref. 


Program Header 


7-3 


Program Header 


7-3 


Program Header 


7-3 










Segment Header 


7-3 


Execute 


7-4 


Execute 


7-5 


Execute 


7-5 


Origin 


7-6 


Origin 


7-7 


Origin 


7-7 


Modular Origin 


7-7 


Modular Origin 


7-7 


Modular Origin 


7-7 






Literal Origin 


7-8 


Literal Origin 


7-9 


Admode 


7-9 


Admode 


7-9 


Admode 


7-10 


Equals 


7-10 


Equals 


7-10 


Equals 


7-11 


Control Equals 


7-11 


Control Equals 


7-11 


Control Equals 


7-12 


Memory Dump 


7-12 






Skip 


7-13 










Suffix 


7-13 










Repeat 


7-14 










Generate 


7-14 


Clear 


7-15 


Clear 


7-16 


Clear 


7-17 


End 


7-17 


End 


7-18 


End 


7-19 



Program Header 
PROG 



A 


B 


C 









The program header must be the first entry in a symbolic program. This statement is 
coded as follows for the various assembly systems. 

EASY CODER A 

The letters PROG must be written in the op code field, and the operands field must contain 
a name which identifies the program. (This name will appear in the program listing.) Optionally, 
an "S" can be placed in column 6; this action specifies that a check is to be made on the card 
number sequence of the input deck. 

EASYCODER 

CODING FORM 



PROGRAMMER DATE 



CARD 

NUMBER 


7 

I 


a 


LOCATION 


OPERATION 

CODE 


OPERANDS 




1 2^ 1 3 4 1 5 






e. . 1 . . .14 


■5| . . . .20’ 


1 .... 1 1 .... 1 .62 




-1^ 


§ 




. 1 . . 


P.RQG 



















' ' ' ' ■ 
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In the sample above, SERIES is specified as the program name, while the letter S in 
column 6 designates that a sequence check is desired. 

EASYCODER B 

The letters PROG must be written in the op code field, and the operands field must contain 
a name which identifies the program. (This name will appear in the program listing. ) Optionally, 
an "S" can be placed in column 6; this action specifies that a check is to be made on the card 
number sequence of the input deck. 

In addition, the desired object program format is specified by the entries in columns 61 
and 62. Blanks in these two columns specify that the machine -language output is to appear in 
the condensed-card self-loading format. Placing the letters BR in these columns specifies that 
the machine -language program is to appear on punched cards in BRT format. (See Easycoder 
8K Operating Procedures, DSI-406. ) 

NOTE: When BRT format is specified, a segment number of 01 is generated by the 
Assembly Program for the first segment (memory load) following the pro- 
gram header. If Execute statements (see page 7-4) appear in the symbolic 
program, subsequent segment names are generated by incrementing the 
previous segment number by one. 

EASYCODER 

CODING FORM 



PROBLEM PROGRAMMER DATE PAGE OF 



CARO 

NUMBER 


T 


R 


LOCATION 


OPERATION 

CODE 


OPERANDS 




1 2 |3 4l 5 


6 


7 


0 1 . , ,14 


I5i . . .20 


21 1 1 1 1 ■ 1 1 1 1 1 62 


1 1 , 1 . , 1 1 . . , 1 . 1 . 


1 1 


S 




, 


P.RQQi 


S.E,R\!E,S . , , , iBR 








__ 


...... 


1 . . . . 


■ ■ ■ 1 La . . 1 L__t_ J . 1 . . . ■ 1 . ■ . ■ 1 ■ ■ ■ ■ 1 ■ . . ■ 1 . 





The statement above designates SERIES as the program name and specifies that a sequence 
check is to be performed. As columns 6l and 62 contain the letters BR, the output will appear 
on punched cards in BRT format. 



EASYCODER C 

As used in the Easycoder C Assembly System, the program header provides program 
identification; in addition, however, this statement serves as the all-important "action director" 
statement. For this reason, the programmer should refer to the Honeywell publication Easycoder 
Assembly C Operating Procedures (DSI-315A) for a detailed description. 



Segment Header 
SEG 




Programs written for Easycoder C assembly may be divided into two or more segments. 
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each of which is loaded into memory and executed as a unit. It is the function of the SEG state- 
ment to define the beginning of each segment (memory load). Use of the SEG statement is op- 
tional, however. If used, a SEG statement must follow the program header and each Execute 
statement. If it is desired to omit this statement, it must be omitted from the entire programj 
in this case the assembly program generates segment identifications (starting with 01). 

EASYCODER C 

The letters SEG must be placed in the op code field, while the operands field must contain 
a two -character segment identification. This segment identification becomes appended to the 
program name to form a unique search code. 

EASYCODER 

CODING FORM 



PROGRAMMER nATp PAGE 



CARD 

NUMBER 


7 

1 


f 

R 

K 


LOCATION 


OPERATION 

CODE 


OPERANDS 




1 ,2 1 3 ,4| 5 


6 


7 


8 1 14 


15, , 20 


1 .■■■ 1 .... 1 .... , , . . 1 . , . , 1 62 


. 1 . . . . 1 . , 1 , 60 


zpr 


- 


- 


^ I . ■ ■ 


5EG 


AA 


. ■ 1 ■ ■ 1 1 . . . 



In the example above, AA could represent the first segment of a program, in which case 
this entry would follow the program header. 



Execute 

EX 



A 


B 


C 









The end of a memory load is indicated by an EX statement. When the coding inserted by 
the assembly program for the EX statement is encountered during the loading process, a branch 
to the location specified in the operands field results. This operation enables portions of the 
program to be executed before the entire program has been loaded. The coding to be executed 
ryiust appear prior to the EX statement. 

EASYCODER A 

The letters EX must be written in the op code field; the operands field contains a direct 
address, either absolute or symbolic. (If an EX statement is written with a blank operands 
field, the machine will halt when it encounters the corresponding coding during the loading 
operation. ) 

To resume the loading operation, the last instruction in the portion of the program executed 
must be a Branch instruction which provides re-entry to the load routine. In addition, the first 
instruction of the executed routine should be an SCR (Store Control Registers) instruction which 
stores the contents of the B-address register in the A address of the return Branch instruction. 
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EASYCODER 

CODING FORM 



PROBLEM __ ^ PROGRAMMER DATE PAGE OF 



CARD 

NUMBER 


1 


f 

R 

K 


LOCATION 


OPERATION 

CODE 


OPERANDS 




1 ,2 1 3 ,4| 5 


6 


1 


0 , I , , 14 


15, 20 


. 1 . . . . 1 . . . . 1 . 1 r . 1 . , . , 1 1 , . 1 .... 1 ,62 


. 1 1 . . 1 . . 1 . 90 








^ ■ 1 ■ ■ ■ 




SEca 




1 















The sample statement above illustrates an EX statement with a symbolic address in the 
operands field. When the corresponding coding is encountered during the loading operation, pro- 
gram loading is temporarily halted and the portion of the program beginning at the location tagged 
SEG3 is executed. 

EASYCODER B 

The letters EX must be written in the op code field; the operands field contains a direct 
address, either absolute or symbolic. (If an EX statement is written with a blank operands field, 
the machine will halt when it encounters the corresponding coding during the loading operation. ) 

To resume the loading operation, the last instruction in the portion of the program executed 
must be a Branch instruction which provides re-entry to the load routine. In addition, the first 
instruction of the executed routine should be an SCR (Store Control Registers) instruction which 
stores the contents of the B-address register in the A address of the return Branch instruction. 

Besides causing a branch to the programmer's coding, use of the EX statement causes any 
literals used in the memory load to be loaded and the literal table to be cleared. If a LITORG 
statement (see below) does not precede the EX statement, literals are allocated immediately 
following the in-line coding for the memory load. 

NOTE: Following an EX statement, a new segment number is generated as explained 

above in the description of the program header. 

See the sample statement given above for Easycoder A. 

EASYCODER C 

The letters EX must be written in the op code field; the operands field must contain a 
direct address, either absolute or symbolic. When used with this assembly system, the EX 
statement enables a program to be loaded and executed one segment at a time. Each segment 
except the last must end with this statement. 



Note that it is the responsibility of the programmer to provide re-entry to the load routine. 
The methods of returning to the applicable loader are described in the pertinent Honeywell 
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publication (e.g., the PLUS — Card Loader-Monitor bulletin, DSI-349, or the PLUS — Tape 
Loader - Monitor bulletin, DSI-327). 

See the sample statement given above for Easycoder A. 



Origin 

ORG 




The ORG statement is used to modify the normal memory allocation process of assembly. 
This statement can be inserted anywhere in the source program to indicate to the Assembly Pro- 
gram that all subsequent coding (instructions, constants, work areas, etc.) should be assigned 
sequential memory locations starting with the location whose address is specified in the operands 
field. 



A program is normally allocated memory space beginning at location 0. If it is desired to 
assign memory space starting at some location other than location 0, an ORG statement must be 
inserted into the program immediately following the program header. 

EASYCODER A 

The letters ORG are written in the op code field, and an address (either absolute or sym- 
bolic) is written in the operands field. (If the address is symbolic, the tag must appear in the 
location field of a previous source program entry.) The address specified in the opereinds field 
is assigned the tag (if any) in the location field; if this tag appears, it must not be indented. 

EASYCODER 

CODING FORM 



PROBLEM PROGRAMMER DATE PAGE OF 



CARD 

NUMBER 


1 




LOCATION 


OPERATION 

CODE 


OPERANDS 




1 2 |3 4l 5 


6 


7 


8. . , . , ,14 


15, . , . ,ZO 


2'. ... 1 .... 1 .... I . 1 1 . .... 1 


63. 1 1 . 1 , 1 1 1 1 . , 1 , 1 , i®® 




1 


1 








■■■■■■■■■■■■I 


■HH 












, 


or 






. . 1 . . 


QRO . . 


. . . . 


—i L.. 1 i I .I. ■ 1 ■ . ■ . 



The first statement above indicates to the Assembly Program that all subsequent entries 
should be assigned sequential addresses beginning with location 750. The second statement 
directs the Assembly Program to assign to all subsequent entries sequential addresses begin- 
ning with the address that is assigned to the tag ORTAG. (ORTAG must appear in the location 
field of a previous source program entry. ) 
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EASYCODER B 

The letters ORG are written in the op code field, and an address (either absolute or sym- 
bolic) is written in the operands field. (If the address is symbolic, the tag must appear in the 
location field of a previous source program entry. ) The address specified in the operands field 
is assigned the tag (if any) in the location field; if this tag appears, it must not be indented. 

NOTE: When the BRT punched-card format is specified, an ORG statement must 

be included immediately following the PROG statement with an address of 
1, 000 (decimal) or above. 

See the sample statements given above for Easycoder A. 

EASYCODER C 

The letters ORG are written in the op code field, and an address (either absolute or sym- 
bolic) is written in the operands field. - If the address is symbolic, the tag must appear in the 
location field of another — not necessarily previous — source program entry. — The address 
specified in the operands field is assigned the tag (if any) in the location field; if this tag ap- 
pears, it must not be indented. 

NOTE: Care must be taken so that the address in the operands field is a decimal 

number of 1,000 or above if Card Loader -Monitor B is used to load the 
object program. If Tape Loader -Monitor C or Drum Bootstrap-Loader C 
is used, this decimal number must be 1, 340 or above. 

See the sample statements given above for Easycoder A. 



Modular Origin 
MORG 



A 


B 


C 









The modular origin statement is similar to the ORG statement described above. The 
MORG statement indicates to the Assembly Program that all subsequent entries should be as- 
signed sequential addresses starting with the next available location whose address is a multiple 
of the number written in the operands field of the MORG statement. The entry in the operands 
field must represent a power of two (e. g. , 2, 4, 8, 16, 32, 4, 096, etc. ). 



EASYCODER A, B. and C 

The letters MORG are written in the op code field, and a number (a power of two) is placed 
in the operands field. 



7-7 





SECTION 7. ASSEMBLY CONTROL STATEMENTS 



EASYCODER 

CODING FORM 



PROBLEM 


^ 










KKUbKAMMER__ _ date PARF OF 


L U 

NUMBER 

1 , 2)3 4 1 5 


Y 

i 

6 


R 

K 

7 


LOCATION 


OPERATION 

CODE 


OPERANDS 

21, III, 




1 7 

— 






I c - 1 ■ . . 




32, , , , ^ — 


1 1 . i . . 1 , , . 1 . , 00 








■ 1 . . . 


, 




i 1 . 1 1 1 , . . . 












--L.__L._1 J L..X. __l__.l I ...L 1. ..1 _1_ ... 



The statement above indicates to the assembly program that all subsequent entries should 

be assigned sequential addresses beginning with the next available location whose address is a 
multiple of 32. 



Literal Origin 
LITORG 




The literal origin statement is similar to the ORG and MORG statements described above. 
The LITORG statement specifies to the Assembly Program that all previously used literals should 
be assigned sequential memory locations starting with the location specified in the operands field. 
In the absence of a LITORG statement, all of the generated coding associated with a memory load 
is allocated immediately following the in-line coding. 

Care must be taken to ensure that literals can be referenced by the instructions which use 

them; e. g. , a literal stored in one 4K bank may not be addressed in the two -character mode 
from another bank. 



EASYCODER B 

The op code field must contain the letters LITORG, while the operands field contains an 
address (either absolute or symbolic); this address is assigned the tag, if any, in the location 
field. If a symbolic tag is used, it must have appeared in the location field of a previous entry. 
Like the EX statement, the LITORG statement causes the literal table to be cleared. Also, lo- 
cations below 1, 000 (decimal) must not be used when BRT punched-card output is specified in the 
PROG statement. 



EASYCODER 

CODING FORM 



PROGRAMMER _ _ _._DATE 



CARD 

NUMBER 

1 2 1 3 4 1 5 


1 

1 

6 


R 

7 ■ 


LOCATION 

8 . 14 


OPERATION 

CODE 


OPERANDS 






- 


- 








1 1 . 1 . . 1 . , , 1 . 80 


ht -H 


__ 




- 


- ‘ — 







In the LITORG statement above, the Assembly Program is directed to assign sequential 
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addresses — starting with location 1550 — to all previously encountered literals. This instruc- 
tion is also tagged LIT. (Note that the tag begins in column 8; it must not be indented. 

EASYCODER C 

The op code field must contain the letters LITORG, while the operands field contains an 
address (either absolute or symbolic); this address is assigned the tag, if any, in the location 
field. If a symbolic tag is used, it must have appeared in the location field of a previous entry. 
Like the EX statement, the LITORG statement causes the literal table to be cleared. Also, lo- 
cations below 1, 340 (decimal) must not be used. 

See the sample statement given above for Easycoder B. 



Set Address Mode 
ADMODE 



A 


B 


C 









This statement specifies the addressing mode into which all subsequent instructions are to 
be assembled (i. e. , two-, three-, or four -character). (All machine instructions, as well as the 
DSA data formatting statement, are affected by the address mode. ) The mode of address as- 
sembly specified in this statement remains in effect until another ADMODE statement, specifying 
a different mode of assembly, is encountered. 

Because the ADMODE statement concerns itself only with the source program , it should be 
used in conjunction with the CAM (Change Addressing Mode) instruction (see page 8-69). The 
CAM instruction specifies the addressing mode in which the machine is directed to interpret the 
address portions of all subsequent object program instructions. 

EASYCODER A and B 

The letters ADMODE are placed in the op code field. The operands field contains either 
a Z or a 3 to denote whether all subsequent instructions are to be assembled in the two -character 
or the three -character addressing mode. If an ADMODEl statement is not included at the begin- 
ning of the source program, assembly begins in the two -character addressing mode. (It should 
be a general rule, however, to include an ADMODE statement at the outset of every program. ) 

EASYCODER 

.CODING FORM 



PROGRAMMER DATE PAGE OF. 



PROBLEM _ 

CARD 

NUMBER 


1 


11 

R 


LOCATION 


OPERATION 

CODE 


OPERANDS 












15, 20 




63. , , . , , 60 










ADMODE 




, , ; , , , , 




, 


' 1 












' j T" 








ADMODE 


3 . 1 . . , . 1 . , , , 1 . . . 1 . . 1 . 1 .J__l 1 i_I. J— L- i-._-i-.l - 


, , 1 , 1 I 1 1 , . . i 1 i 1 . 1 


1 1 
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The Assembly Program, upon encountering the first statement above, will assemble the 
address portions of all subsequent instructions as two -character addresses. The second state- 
ment, if encountered later in the same source program, will cause the Assembly Program to 
change to three -character address assembly. 

EASYCODER C 

The letters ADMODE are placed in the op code field. The operands field contains a 2, 3, 
or 4 to denote whether all subsequent instructions are to be assembled in the two-, three-, or 
four -character addressing mode. If an ADMODE statement is not included at the beginning of 
the source program, three -character addressing is assumed by assembly. (It should be a 
general rule, however, to include an ADMODE statement at the outset of every program. ) 

See the sample statements given for Easycoder A and B. 



Equals 

EQU 



A 


B 


C 









The EQU statement assigns the symbolic tag written in the location field to the address 
(absolute or symbolic) written in the operands field. This statement thus makes it possible to 

use different symbolic tags in different parts of the source program to refer to the same memory 
location. 

EASYCODER A and B 

The location field contains a symbolic tag, while the op code field contains the letters EQU. 
The operands field contains the address to which the symbolic tag in the location field is to be 
assigned. (Each symbolic tag written in the operands field must appear in the location field of 
a previous source program entry. ) 



EASYCODER 

CODING FORM 



CARD 

NUMBER 

1 2 |3 4l 5 


F 

1 


R 

7 


LOCATION 
e I 14 


OPERATION 

CODE 

15, 20 


OPERANDS 


E PAGE OF 








T^T.LE 


EQU 


name. 


. .80 


1 ■ 1 






. 1 ■ ■ ■ 


— J . ■ . ■ 




— f 1 , 1 1 1 , . . 


1 ! 


- 


L 


OUAN 


E,QU 


AMT-ZO. . 


' ' 1 ' 1 1 1 1 1 ^ I ■ 1 ■ ■ . . 



The first EQU statement above causes the Assembly Program to assign the tag TITLE 
the same location assigned the tag NAME. Thus, the programmer can use either of these two 
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tags to refer to the contents of this location. The second statement employs relative addressing. 
The Assembly Program will assign the tag QUAN to the location specified by address arithmetic 
as AMT-20. 

EASY CODER C 

The location field contains a symbolic tag, while the op code field contains the letters EQU. 
The operands field contains the address to which the symbolic tag is to be assigned. (A symbolic 
tag written in the operands field must appear in the location field of another — not necessarily 
previous — source program entry). 

See the sample statement given above for Easycoder A and B. 



Control Equals 
CEQU 




The CEQU statement assigns the symbolic tag written in the location field to the octal value 
written in the operands field. It is frequently used to assign a tag (containing a minimum of two 
characters) to a variant character or to a group of input/output control characters. 

The octal value written in the operands field (although coded as an octal constant) is still 
treated as an assembly definition. Consequently, it does not appear as an object program entry. 

EASYCODER A and B 

The location field contains a symbolic tag, while the op code field contains the letters 
CEQU. The operands field contains the octal value; this entry is coded as an octal constant and 
may contain up to 12 octal digits. The symbolic tag in the location field is assigned to this entry. 

NOTE: A description of octal constants may be found under the heading "Define 

Constant with Word Mark — DCW" (see page 6-2). 

EASYCODER 

CODING FORM 



PROGRAMMER DATE 



CARD 

NUMBER 


1 , 


11 

R 


LOCATION 


OPERATION 

CODE 


OPERANDS 








7 


8 1 14 


I5| 20 


21. ... 1 .... 1 .... 1 .... 1 .... 1 .... 1 . 1 .... 1 


63. , , . . . 1 ... .60 


_r=r 






OF LOW 


CEQU 


frlCbOft ..... . 


1 L 1 i . 1. 1_ .a . 1 . 


' 1 • 








acT 


SUB2., OFLOW . . . . , . 


.. .1. i. ,i .-r- i... L..J — — L_ 


— ‘ 1 ‘ 1; ' 
1 1 















The sample coding above illustrates how a symbolic tag can be used in place of a variant 
character. The CEQU statement directs the Assembly Program to equate the tag OFLOW to the 
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octal value 50. The second line of coding contains a branch instruction which specifies that a 
program should branch to the location tagged SUB2 if the condition specified by the variant 
character tagged OFLOW is present. 

EASY CODER C 

The location field contains a symbolic tag, while the op code field contains the letters 
CEQU. The operands field contains the octal value; this entry is coded as an octal constant 
and may contain up to eight octal digits. The symbolic tag in the location field is assigned to 
this entry. 

NOTE: A description of octal constants may be found under the heading "Define 
Constant with Word Mark — DCW" (see page 6-2). 

See the sample statement given above for Easycoder A and B. 



Memory Dump 
HSM 



A 


B 


C 









The HSM statement may be used with Easycoder A to produce a punched card deck con- 
taining the Memory Dump routine. This card deck can be loaded into memory to obtain a printed 
listing of the contents of any portion of main memory. This statement must be coded immediately 
preceding the CLEAR and END statements in the source program (see below). 

EASYCODER A 

If the punched card deck (containing the Memory Dump routine) is to be loaded into a spe- 
cific memory area, the start of this area can be specified by a tag in the location field of the 
HSM statement. A blank location field causes the Memory Dump routine to be loaded into the 
area following the location assigned to the last character in the object program. The letters 
HSM must be written in the op code field. The operands field contains the addresses of the first 

(low) and last (high) locations in the memory area whose contents are to be listed by the Memory 
Dump routine. 



EASYCODER 

CODING FORM 



CARD 

NUMBER 

1 2 |3 4| 5 


i 

6 




LOCATION 

6 1 14 


OPERATION 

CODE 

15, 20 


KHOGRAMMER nfl' 

OPERANDS 


'E PAGE _0F 




- 


[ 


. , 1 ■ . 


H5M , . 


start.s.to.p.4-3 ' 


i , .80 

' 1 ' 



The HSM statement above specifies that the area whose contents are to be listed begins 
at the location tagged START and ends three locations beyond the location tagged STOP. As the 
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location field is blank, the Memory Dump routine will be stored in the area following the location 
assigned to the last character in the object program. 



Skip 

SKIP 



A 


B 


C 









The Assembly Program normally single-spaces an assembly listing and skips to the head 
of the next form when a page becomes filled. The SKIP statement enables the programmer to 
control the vertical spacing of the assembly listing by causing as many as 15 lines to be skipped. 

EASYCODER C 

The letters SKIP are placed in the op code field. The operands field contains either a 
number from 1 to 15 (to indicate the total number of lines to be skipped) or the letter H (which 
causes the printer to skip to the head of the next form). 

NOTE: The Assembly Program automatically skips to the head of the form for 
each new segment. 



EASYCODER 

COOING FORM 



PROGRAMMER —DATE PAGE- — OF 



CARD 

NUMBER 


FI 

I 


m 

R 


LOCATION 


OPERATION 

CODE 


OPERANDS 






6 


7 


e , , ,14 


15, . ,20 


21. ... 1 .... 1 .... 1 , , 1 , . , , 1 , . ■ .. . ] 


63. , 1 1 ,80 


-Id- 


_ 


_ 




SKIP. 


9 .... 1 .... 1 ... , 1 . 


. ■ ] . . 1 1 1 ■ . . i 1 . 1 i 







In the sample coding above, the Assembly Program is directed to skip 9 lines on the program 



listing. 



Suffix 

SEX 



The SFX statement directs the Assembly Program to append the single -character suffix in 
the operands field to each tag of five characters or less contained in the following coding. This 
technique enables the programmer to assign unique tags for each segment of a program and thus 
guard against double definition of a tag between distinct segments of a program. When inter- 
segment referencing within a program is required, six-character tags may be assigned. 

This operation continues until the occurrence of another SFX statement with a blank 
operands field, or until the END statement is encountered. 
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EASYCODER C 



The letters SEX are placed in the op code field. A single-character suffix is written in 
the operands field. 



EASYCODER 

COOING FORM 



PROBLEM PROGRAMMER DATE PAGE OF. 



CARD 

NUMBER 


1 


m 

R 

K 


LOCATION 


OPERATION 

CODE 


OPERANDS 




1 2 1 3 4 1 5 


6 


7 


8. . 1 . . .14 


15, _ 20 


, 1 . , , , , 1 .62 


63^ 1 1 1 1 1 1 I I 1 1 8® 








, . 1 . . . 


S,FX 


. 










TOTAL 


A, . . . . 


FICA+,TOTAK-20 , 










^ ..i ■ , ^ 


1 ... . 






1 1 















In the above example, the Assembly Program interprets the Add instruction following the 
SEX statement as: TOTALE A EICAE+TOTAXE-20. 



Repeat 

REP 



A 


B 


C 









This statement, used with the constant-defining statements DC and DCW, directs the 
Assembly Program to repeat the following statement the number of times specified in the 
operands field. The number of times a statement is repeated includes the original statement and 
may not exceed 63. The Assembly Program repeats the statement without variation. 

EASYCODER C 

The letters REP are written in the op code field. The operands field designates the number 
of times the following statement is to be repeated (including the original statement). 



EASYCODER 

CODING FORM 



_ _ PROGRAMMER DATE 



CARD 

NUMBER 


1 


f 

R 

K 


LOCATION 


OPERATION 

CODE 


OPERANDS 




1 2 1 3 4l 5 


i 


7 


8 .. 1 ... 14 


15, _ , 20 


.u . . 1 . . . . 1 . , , . , 1 , , , , 1 ,62 




- 4^1 






. . 1 . . 


REP 













OCTS6 


DCW ^ 











- 


. . 1 . . 




1-^ ... 1 .... , , . , . . , , 


■ ■ 1 ■ ■ ■ ■ 1 ■ ■ ■ ■ , 1 



In the sample statement above, REP is employed to define six identical constants of octal 
value 6000. 



Generate 

GEN 



A 


B 


C 






. 
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This statement directs the Assembly Program to generate the instruction which follows a 
specified number of times, incrementing or decrementing the operands of the instruction as 
specified by the operands field of the GEN statement. The GEN statement can apply to machine 
instructions with formats containing a single address, both addresses, a single address and one 
variant character, or both addresses and one variant character (only one variant character is 
allowed). 

EASYCODER C 

The letters GEN are written in the op code field. The operands field contains the parameter 
specifying the number of times the statement (which follows) is to be generated, including the 
original statement. This number is followed by a modifier for each operand in the model state- 
ment. These modifiers specify the increment (from 0 to +63) or decrement (from -63 to 0) to be 
applied to each of the operands each time the statement is generated. There must be a modifier 
for each operand in the model statement (including the variant character, if any), and the 
modifiers must appear in the same order as the operands. If no modification is desired, 0 is 
entered as the modifier. 



EASYCODER 

CODING FORM 



PROGRAMMER DATE 



CARO 

NUMBER 


T 


1 

R 


LOCATION 


OPERATION 

CODE 


OPERANDS 












I5| , ^ 20 


21 1 , . . . 1 . . . , 1 , , , , 1 , , . 


63 , 1 . ,80 










0,EN , 


10 , t4,,.+ 6...(z5, . . . . 


. . 1 ....ill.... 








SWCj_ 


B£E 


SEL . TABLE , ,8 . 


. . 


1 1 














1 1 

— +-^T- 






TABLE 


RFSV 


A0 . . , ■ . 1 , 


1 1 • 











In the example above, the GEN statement generates a series of 10 instructions that will 

branch to a location SEL, SEL+4, SEL+8, or SE<L+36, provided that an 8 is present 

in the first character of the corresponding item in a table containing 10 six-character items. 
The tag SWC is assigned to the leftmost character of the first generated instruction. The GEN 
statement itself must not be tagged. 

NOTE: The second BCE instruction generated by the example is BCE /SEL+4, 

TABLE+6, 8; the third instruction generated is BCE/SEL+8, TABLE+12, 8; 
and so on. The tenth instruction generated is BCE/SEL+36, TABLE+54, 8. 



Clear 

CLEAR 




The CLEAR statement enables the programmer to specify an area of memory which is to 
be cleared of punctuation before the object program is loaded. The memory area is also 
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cleared to zeros or to a given character. It is not necessary to clear areas which will be used 
to store the object program. 

EASYCODER A 

The op code field contains the letters CLEAR, while the operands field contains the ad- 
dresses (either absolute or symbolic) of the first (low) and last (high) locations in an area to be 
cleared. If a comma is written immediately following the second address, the character written 
in the column after the com.ma is loaded into all locations in the cleared area. If two addresses 
are written in the operands field and are not followed by a comma and a character, the specified 
area is cleared to zeros. 

A number of CLEAR statements may be written in sequence, immediately preceding the 
end statement, provided that the total number of HSM!, CLEAR, and END statements does not 
exceed 10. 

NOTE: The 80-character loading area specified in the END statement must 
never be cleared. 

EASYCODER 

COOING FORM 



PROGRAMMER DATE PAGE OF. 



CARD 

NUMBER 


1 


i 


LOCATION 


OPERATION 

CODE 


OPERANDS 




1 .2 |3 4| 5 




7 




. 20 


■ >■ 1. L ■ . 1 1 . 1 . . 1 , 1 ,62 


63. , 1 ... , .80 


' [ ' I 






.... 


CLEAR 


Camt,,eamt . 




-- 1 • 1 






. . 1 


1 . . . , 












— ^1 . ■ ■ 









^4 


- 


- 


-^-^1 . . . 


. ■ ■ 




— ^--■-1 ■ ■ ■ ■ 1 . . ■ . 1 ■ ■ . ■ 



The first CLEAR statement above specifies that the area beginning at the location tagged 
CAMT and ending at the location tagged EAMT is to be cleared to zeros. The second CLEAR 
statement clears the area beginning at location 3-34 and ending at 379 to 46 J's. 

EASYCODER B 

The op code field contains the letters CLEAR, while the operands field contains the ad- 
dresses (either absolute or symbolic) of the first (low) and last (high) locations in an area to be 
cleared. If a comma is written immediately following the second address, the character written 
in the column after the comma is loaded into all locations in the cleared area. If two addresses 
are written in the operands field and are not followed by a comma and a character, the specified 
area is clear€;d to zeros. 

A maximum of nine CLEAR statements may be included in a program. In addition, no 
coding may appear between the last symbolic CLEAR statement and the END statement. 
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NOTE: The loading area specified in the END statement must never be cleared. 

See the sample statements given above for Easycoder A. 

EASYCODER C 

The op code field contains the letters CLEAR, while the operands field contains the ad- 
dresses (either absolute or symbolic) of the first (low) and last (high) locations in an area to be 
cleared. If a comma is written immediately following the second address, the character written 
in the column after the comma is loaded into all locations in the cleared area. If two addresses 
are written in the operands field and are not followed by a comma and a character, the specified 
area is cleared to zeros. As many CLEAR statements as necessary can be included in a pro- 
gram. 

NOTE: The programmer must exercise caution in the physical placement of the 
CLEAR statement, as the clearing is performed by the Loader at the 
time the CLEAR statement is encountered. 

See the sample statements given above for Easycoder A. 



End 

END 




The last source program instruction must be the END statement, which indicates to the 
Assembly Program that the end of the source program has been reached. 

EASYCODER A 

The location field may contain an address (either absolute or symbolic) which specifies the 
initial location in an 80-character loading area. If the location field is left blank, the Assembly 
Program automatically reserves an 80-character loading area following the location assigned 
to the last character in the object program. 

The op code field contains the letters END. If it is desired to execute the object program 
immediately after loading, the operands field must contain the address (either absolute or 
symbolic) at which the object program is to begin. If the operands field is blank, the machine 
halts after the load operation has been completed. 



EASYCODER 

CODING FORM 

PROBLEM PROGRAMMER DATE PAGE OF 



CARD 

NUMBER 


I 




LOCATION 


OPERATION 

CODE 


OPERANDS 




1 2 1 3 4 1 5 


6 


7 


8 . , ... 14 


15, 20 


2', . , . 1 , , , . 1 . . . , 1 . 1 . , 1 . , . . , , 1 , , , , 1 


1 1 , 1 , . 1 1 1 , , 1 . 1 . 


1 1 








EMD. 


OBOECT . . . 




r 1 ' 
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The END statement above specifies that the object program (beginning at the address 
tagged OBJECT) is to be executed immediately after loading. Since the location field is blank, 
the Assembly Program will reserve an 80-character loading area following the location assigned 
to the last character in the object program. 



EASYCODER B 

The method of coding this statement depends on which output format has been specified in 
the program header statement. 

1. Output in self-loading format: The location field may contain an address 

(either absolute or symbolic) which specifies the initial location in an 80- 
character loading area. If the location field is left blank, the assembly 
program automatically assigns an 80-character loading area following 
the location assigned to the last character in the object program. 

The op code field contains the letters END, while the operands field 
contains the address (either absolute or symbolic) to which the Loader 
branches when loading has been completed. If the operands field is blank, 
the machine halts after the load operation has been completed. 

NOTES: a. The programmer should ensure that the loading 
area does not span two 4K memory banks. 

b. During the loading process, the object program 
must not use the loading area. However, the 
area may be used following program loading. 

c. When literals are used, the programmer must 
specify a loading area that does not coincide 
with the memory area occupied by literals. 

2. Output in BRT format: The op code field contains the letters END, while 
the operands field contains the address (either absolute or symbolic) to 
which the Loader branches when loading has been completed. If the 
operands field is blank, the machine halts after the load operation has been 
completed. When BRT format is specified, all other fields of the END in- 
struction are ignored by the Assembly Program. 

NOTE: The loading area is automatically assigned by the Loader. 



EASYCODER 

CODING FORM 



PROBLEM __ _ PROGRAMMER DATE PAGE OF 



CARD 

NUMBER 


1 


R 

K 


LOCATION 


OPERATION 

CODE 


OPERANDS 




1 2 1 3 4| 5 


6 


7 


8 _ , 14 


15, , . . .20 


. .1. . , .1 . . . .1 . j L_. , , 1 , , , . 1 , , . , 1 . . , . 1 


63 , I , 1 , , , 80 


-i-l- 








ENP , 


QB.JECT, . . , 




1 






1 


- 1 . ■ ■ . 






1 . 1 






.i ( L 


END . . 


OBO.E.CT. ........ 




1 1 















The first example above illustrates the coding which may be used for self-loading format 
output; the coding for BRT -format output is shown in the second example. 
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EASYCODER C 

The op code field contains the letters END. An address must appear in the operands field; 
the Loader will branch to that address (which should be the starting location of the last segment 
of the program). 

NOTE: The loading area is automatically assigned by the Loader. 



EASYCODER 

COOING FORM 



PROGRAMMER ^DATE PAGE OF 



CARD 

NUMBER 




R 


LOCATION 


OPERATION 

CODE 


OPERANDS 




1 2 1 3 4 1 5 


6 


7 


8 1 14 


15, 20 


a. ... 1 ......... 1 .... ■ . . ■ 1 


63, , I . , . , ,60 










EMO , 


S TART.L , , . . 


, , , 


‘ t H 















The sample END statement above indicates to the Assembly Program that the end of the 
source program has been reached. This statement is replaced by coding which specifies to the 
Loader that the last (or only) segment begins at symbolic address STARTL. 
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8 

INSTRUCTIONS 



INTRODUCTION 

A Series 200 computer operates under the direction of instructions in the stored program. 
For descriptive purposes, these instructions are classified into six functional categories: (1) 

Arithmetic, (2) Logic; (3) Control; (4) Interrupt Control; (5) Editing; and (6) Input /Output. 



All instructions are described in the following standard format: 



Title: The title describes the instruction. It appears in the lefthand 

margin of a page, along with the mnemonic .operation code used 
in the Easycoder symbolic programming language. 

If an instruction is included in an optional feature, that feature 
number accompanies the title. 

Format: This is a tabular representation of the formats which may be 

used when coding the instruction. 

Function: The function of the instruction is described in terms of the 

format in which it is coded. 



Word Marks: The effect of word marks with regard to data fields is specified. 

Timing: The formulas to be used in calculating the timing of the instruc- 

tion (in memory cycles) are presented. These formulas are 
for instructions using direct addressing. If address modification 
is to be used, the formulas should be modified as follows: 



!• Indirect Addressing — Add one memory cycle for 

each character extracted as a result of indirect 
addressing. 

2. Indexed Addressing — Add three memory cycles 

for each indexed address. 

Address The contents of the address registers are indicated for each of 

Registers the instruction's formats. 

after 

Operation: 



Notes: This is additional information pertaining to the operation. 

Examples: Practical applications of the instruction in its various formats 

are described and illustrated as symbolic program entries. 
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SECTION VIII. INSTRUCTIONS 



Table 8-1 lists the abbreviations and symbols used in the description of the instructions. 
Those symbols used only with specific instructions are preceded by the title of the instruction 
to which they pertain. 



Table 8-1. Symbology Used in Series 200 Instruction Descriptions 



SYMBOL 


MEANING 


A 


A address of the instruction 


B 


B address of the instruction 


Ni 


Number of characters in the instruction 


N 

a 


Number of characters in the A field 


Nfe 


Number of characters in the B field 


Nw 


Number of characters in the A or B field, whichever is smaller 


NXT 


Address of next sequential instruction 


JI 


Address of next instruction if a branch occurs 


A 

p 


The previous setting of the A-address register (AAR) 


B 

P 


The previous setting of the B-address register (BAR) 


1 Multiply 


^ta 


Number of trailing zeros (i. e. , consecutive low-order zeros) in the 
A field 


^mr 


Number of digits in the multiplier 


Z 

mr 


Number of zeros in the multiplier 


s 


Sum of all multiplier digits 


SUM 


The sum of the upwards -rounded values of all multiplier digits 
divided by 2 (see note) 


1 Divide 


^la 


Number of leading zeros in the A field 


Z 


0 if Zia=0; 1 if Z^^^^ 0 


^Id 


Number of leading zeros in the dividend 


Ndd 


Number of digits in the dividend 


N 

q 


Number of digits in the quotient ^ 


Move and Translate 


Net 


Number of characters translated 


Move Item and Translate 


ut 


Number of information units translated 


CSRp 


Previous contents of the change sequence register (CSR) 


NA^ 


Number of six-bit character locations occupied by each A-item 
information unit (1 or 2) 


NB^ 


Number of six-bit character locations occupied by each B-item 
information unit (1 or 2) 
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INTRODUCTION 



Table 


8-1 (cont). Symbology Used in Series 200 Instruction Descriptions 


1 ;■ l¥MBOL 




MovdiSBractdaf s : » 


Z 


Number of characters scanned during zero suppression 


$ 


Number of characters scanned during dollar sign insertion 


1 Store Variant and Indicators 


Ns 


Number of characters stored 




Number of character locations bypassed to reach the next 
sequential op code 


1 Restore Variant and Indicators 




Number of characters referenced 


Input /Output Inst ructions 


N 

c 


Number of control characters in the instruction 


Ncn 


Number of control characters following control character 3 (C3) 



NOTE: The value of SUM is derived in the following manner: 

1. Divide each multiplier digit by 2. 

2. Round off each result to the nearest (upwards) whole digit. 



3. Add together the results arrived at in 2. for each multiplier digit. 

4. The resultant sum = SUM. 
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ARITHMETIC 



• ADD 

•SUBTRACT 

• BINARY ADD 

• BINARY SUBTRACT 

• ZERO AND ADD 
•ZERO AND SUBTRACT 

• MULTIPLY 

• DIVIDE 
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SECTION 8. INSTRUCTIONS 



ARITHMETIC OPERATIONS 

Series 200 add operations (binary addition, decimal addition) treat the A operand as the 
augend and the B operand as the addend. The subtract operations (binary subtraction, decimal 
subtraction) treat the A operand as the subtrahend and the B operand as the minuend. The 
result of each operation is stored in the B field. These elements are summarized in Table 8-2 
where a character enclosed in parentheses indicates the contents of that field. 



Table 8-2. Series 200 Add and Subtract Operations 



ADDITION 




( B ) 
+ ( A ) 


( B ) 
- ( A ) 


( B ) 


( B ) 


BINARY ADDITION 



The Binary Add instruction combines the corresponding bits of the augend and addend and 
produces a binary sum which is stored in the B field. This process can be most readily analyzed 
on a column-by-column basis. For any column in the addition, three variables are significant 
to the sum; the augend digit, the addend digit, and the carry from the next lower-order column. 
For any column, the result is fully expressed by a sum digit (1 or 0) and either a carry or no 
carry to the next higher-order column. Table 8-3 lists all the possible combinations of these 

variables. 



Table 8-3. Binary Addition Table 



PREVIOUS CARRY 






0 


0 












0 


n 




0 












0 






1 


0 


1 


0 






0 


0 


1 


1 


1 


1 


0 


0 




0 


1 


0 


0 


0 


1 


1 


1 



BINARY SUBTRACTION ^ 

The Binary Subtract instruction performs, in effect, twos-complement arithmetic. When 
this instruction is executed, each six-bit character of the subtrahend is converted to its ones 
complement^ and added to the corresponding character in the minuend, adding from right to left. 

^The twos complement of a binary number is formed by subtracting the number from a field of 
all one bits and adding one to the low- order digit of the difference. 

^The ones complement of a binary number is formed by subtracting the number from a field of 
all one bits. 
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ARITHMETIC 



In the first addition (the addition of the low-order characters of the subtrahend and the minuend) 
a simulated carry is added to the result. All subsequent characters are added with or without a 
carry, depending upon the result of the previous addition. 



The word mark associated with the B field terminates the operation. If the length of the A 
field equals that of the B field, the binary subtraction process continues until the high-order B- 
field character has been combined with the high-order A-field character. If the length of the A 
field exceeds that of the B field, the effect is as if there were a word mark in the A-field loca- 
tion corresponding to the high-order B-£ield location (i.e. , the process still terminates at the 
B-field word mark). If the length of the A field is less than that of the B field, zeros are insert- 
ed where the A field terminates until the last B-field character is processed. Each zero is con- 
verted to its ones complement as above and then added to the corresponding B-field character. 



In the following example, locations 294 and 205 contain the value in 12-bit binary form, 

while locations 299 and 300 contain the binary equivalent of STjq. 

Note: Locations 294 and 299 contain word marks; the length of the A field therefore 

equals that of the B field in this example. 



EASYCODER 

CODING FORM 



PROGRAMMER 



CARO 

NUMBER 




LOCATION 


OPERATION 

CODE 


OPERANDS 










15. 20 


21, . . 1 , , , . 1 . . , , 1 . , . . 1 , . , , . . . , 













2 ^ 5 , . 


- ‘ 1 ‘ ‘ ' 



LOCATION -► 

CONTENTS^ 

(binary) 

The six-bit character in location 295 is converted to its ones complement and added to the 
six-bit character in location 300 (see illustration below). Prior to this operation, a simulated 
carry is generated in the adder (see page 2-7). The result of the first addition is the binary 
equivalent of 14^^ plus a carry. This carry remains in the adder and is added to the sum of the 
contents of locations 294 and 299, resulting in a binary zero plus another carry. This final carry 
remains in the adder and the operation terminates. An overflow condition does not exist since 
the carry remaining at the end of the operation is suppressed; consequently the next memory lo- 
cation (location 298) is not disturbed. The result of the entire Binary Subtract instruction is 
therefore 14^^^, the true difference between 87 and 73. 

Table 8-3, indicates how the bits in each column of the ones -complement subtrahend and 
the minuend are combined. 



294 


295 


296 


297 


293 


299 


300 


000001 


001001 


001101 


011011 


011110 


000001 


010111 
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SECTION 8. INSTRUCTIONS 




First Addition 




Second Addition 



The result of the operation (14^^) is stored in the B field as shown below. 
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ARITHMETIC 



DECIMAL ADDITION 

The Add instruction performs either a true add or a complement add, depending upon the 
algebraic signs of the operands. The sign of an operand is determined by the combination of 
zone bits in the units position of that field. The four possible zone bit configurations and the 
signs they represent are shown in Table 8-4. 



Table 8-4. Algebraic Signs in Decimal Addition 



1 




SIGN 








— 


h 


0 0 

1 1 
0 1 


— 


1 0 



True Add 

A true add is performed if the signs of the A and B fields are alike. The result of the 
addition is stored in the B field with the same zone bit configuration that was originally in the B 
field (see Figure 8-1). Zone bits in all B-field locations (except for the units position) are set to 
zeros. A-field zone bits (except for the units position) are ignored. 



(+A) + (+B) = +R 



A OPERAND 



B OPERAND 



+ 244 [ 






+ 170 
+ 244 

+414 RESULT 



(-A) + (-B) = -R 



A OPERAND 



B OPERAND 



-077 [ 



c> 



-444 

-077 

-521 = RESULT 



Figure 8-1. True Add Examples 



Complement Add 

If the operand signs are not alike, the instruction performs a complement add: the A 
operand is converted to its tens complement^ and added to the B operand. The machine automa- 
tically initiates a test to determine whether a carry was generated by the high-order addition. 

^ The tens complement of a decimal number is formed by subtracting the number from all nines 
and adding one to the low-order digit of the difference. 
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SECTION 8. INSTRUCTIONS 



The presence of a carry indicates that the result in the B field is a true answer, and the opera 
tion is terminated with the normalized sign of the B field as the sign of the result (see Figure 
8-2). ^ B-field zone bits (except for the units position) are set to zeros. 



The absence of a carry indicates that the A operand was algebraically larger than the B 
operand and that the result is stored in its tens -complement form. A recomplement cycle is 
performed automatically to convert the result to its true form. The sign of the result is changed 
during this recomplement cycle. Figure 8-2 illustrates complement add operations with without 
recomplementation. 




Figure 8-2. Complement Add Examples 



DECIMAL SUBTRACTION 

The Subtract instruction is analogous to the Add instruction with the exception that before 
the operands are combined, the sign of the A operand is changed. Thus, if the initial sign of the 
A operand is equal to that of the B operand, the operands are combined by a complement add. If, 
on the other hand, the initial sign of the A operand is not equal to that of the B operand, the 
operands are combined by a true add. 

A summary of decimal arithmetic operations is presented in Table 8-5. 

^Normalized signs are expressed bythe following zone bit configurations : plus = 01, minus = 10. 
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ARITHMETIC 



Table 8-5. Decimal Arithmetic Sign Conventions 



OPERATIOH 


A -FIELD 
SIGN 


B- FIELD 
SIGN 


type of add 


SIGN OF RESULT 


ADD 


+ 


+ 


True 


+ (Bit configuration of B) 


- 


Complement 


Normalized sign of greater 
value (- = 10, + = 01) 


- 


+ 


Complement 


- 


T rue 


- 


SUBTRACT 


+ 


- 


True 


- 


+ 


Complement 


Normalized sign of the 
greater value (- = 10, + = 01) 


- 


- 


Complement 


+ 


True 


+ (Bit configuration of B) 



INDICATORS 

Two indicators are set at the completion of every decimal add and subtract operation: the 
overflow indicator and the zero balance indicator. If a carry is generated beyond the limit of the 
B field, the overflow indicator is turned on; if such a carry is not generated, the indicator is 
unchanged, ^ The zero balance indicator signifies either a zero or a non-zero sum. When a 
decimal operation produces a result equal to zero (regardless of sign), the zero balance indi- 
cator is turned on; when the result of the operation does not equal zero, the indicator is turned off . 

These indicators are also set by decimal multiply and divide operations. The overflow 
indicator is turned on when a Decimal Divide instruction is performed in which the divisor is 
equal to zero. The zero balance indicator is turned on if the product of a decimal multiply 
operation is equal to zero. 

The settings of these indicators can be tested by a Branch on Condition Test instruction 
(see page 8-41). This instruction automatically resets the overflow indicator; the zero balance 
indicator is not affected by the branch instruction used to test it but is reset only by the next 
decimal arithmetic instruction. 

MULTIPLICATION 

The Multiply instruction causes the signed decimal integer in the A field (the multiplicand) 



Only a "true add" operation can turn the overflow indicator on (see Table 8-5). 
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SECTION 8. INSTRUCTIONS 



to be multiplied by the signed decimal integer (the multiplier) which is stored in the leftmost lo- 
cations of the B field. The signed product is stored right -justified, in the B field. 



The B field must be large enough to insure an adequate number of locations for the develop- 
ment and storage of the product. Its length is therefore defined as the number of locations in 
the multiplier, plus the number of locations in the multiplicand,, plus one (see Figure 8-3). 



OPERATION: 

aaaa 
X bbb 



HA FIELD- 



A ADDRESS 



LOCATION 

CONTENTS 



A-3 


A-2 


A-1 


A 


© 


a 


a 


a 



MULTIPLICAND 
(4 locations) 



■B FIELD (4+3 + 1 = 8 locations) 

B ADDRESS 



B-7 


B-6 


B-5 


B-4 


B-i 


B-2 


B-1 




B 


© 


b 


b 












^ 



MULTIPLIER 
(3 locations) 



Figure 8-3. A and B Fields in Multiply Operation 



Word marks are required in the leftmost locations of the multiplicand and the multiplier. 
All other locations in the B field must not contain word marks. As shown in Figure 8-3, the 
rightmost location of the multiplier is defined as B - N^ - 1 , where B is the B address and N^ 
is the number of locations in the A field. 



The zone bits in the units positions of the multiplier and the multiplicand indicate the signs 
of the operands. The signs of these factors indicate the sign of the product according to the 
algebraic sign conventions shown in Table 8-6. The sign of the product is expressed in its 
normalized form (minus = 10, plus = 01). 



Table 8-6. Multiply Sign Conventions 



Sign of Multiplicand 


+ 


- 


+ 


- 


Sign of Multiplier 


+ 


- 




+ 


Sign of Product 


+ 


+ 




- 



8-12 




ARITHMETIC 



Consider the following Decimal Multiply instruction., 

EASYCODER 

CODING FORM 



PROBLEM PROGRAMMER DATE PAGE OF. 



CARD ■ 

NUMBER 


5 R 
• K 


LOCATION 


OPERATION 

CODE 


OPERANDS 




1 2 1 3 4 1 5 


7 


8 1 14 


I5| 20 


21. ... 1 .... 1 .... 1 .... 1 .... 1 1 , , , 1 1 


63. . 1 . , , . 1 . , . , 1 . . , so 






X . 1 ^ 









Location 500 is the rightmost location of a four-character field. Location 700 is the right- 
most location of an eight- character field. Location 695 (i, e, , 700 - 4 - 1) is the rightmost loca- 
tion of the multiplier. 



LOCATION- 

CONTENTS 



A ADDRESS 

▼ 



B ADDRESS 

▼ 



497 


498 


499 


500 


i 


3 


2 


6 



093 


694 


695 


69b 


697 




699 


700 




3 


+ 

5 













MULTIPLICAND 



MULTIPLIER 



The data in the A field is multiplied by the data in the field whose rightmost location is 
695, and the product is stored, right -justified, in the B field. All B-field zone bits are cleared 
to zeros (except in the units position, which contains the sign of the product). At the end of the 
operation, the multiplier is no longer present in the leftmost positions of the B field, since all 
B-field locations to the left of the most significant digit of the product are set to zeros. Thus, 
the multiplier should be preserved in another storage field if it is to be used more than once. 
The result of the multiply operation is shown below. 



LOCATION ■ 
CONTENTS 



A FIELD IS PRODUCT IS STORED IN B FIELD, RIGHT- 

NOT DISTURBED JUSTIFIED. ALL INSIGNIFICANT HIGH- 

ORDER CHARACTERS ARE SET TO ZEROS 



iiiiii 


. 498 


499 


.500 




3 


2 





693 


694 


695 


lllll 


iliilll 


698 


699 


700 


® 


2 


7 


7 


7 


z 


1 


0 



PRODUCT 



DIVISION 

The Divide instruction causes the signed decimal integer in the A field (the divisor) to be 
divided into the signed decimal integer whose leftmost location is the B address of the instruc- 
tion (the dividend). The quotient is developed and stored in the leftmost locations of the B field. 
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SECTION 8. INSTRUCTIONS 



and the remainder is stored in the rightmost locations of the B field. ^ To insure an adequate 
number of storage locations for the development of the quotient, the length of the B field is 
determined by adding 1 to the sum of the number of character locations in the divisor and 
dividend (see Figure 8-4). 



OPERATION: 

xx)yyyy 



BEFORE EXECUTION 

FIELDS 
A ADDRESS 



LOCATION- 

CONTENTS 



A-2 


A a 


A 


© 


X 


X 



DIVISOR 
(3 locations) 



B FIELD (3+4+1 =8 locations)- 
B ADDRESS 



B-4 


B-B 




B-1. 


El 


iaiil 


:B.+ 2 


B + 3 


0 


0 




0 


y 


y 


y 


y 





DIVIDEND 
(4 locations) 



AFTER EXECUTION 



LOCATION- 

CONTENTS 



mt 



A+l 



B-Na+Nd-2 



B-Na+Ndd 



B+N, ,-l 









I'-Bm 


■■w 


:Bili 


B+2 


B+3 


q 


q 


q 


q 


0 


r 


r 


r 





QUOTIENT 



REMAINDER 



Figure 8-4. Factor Locations in Divide Operation 



The leftmost location of the dividend is defined by the B address of the Divide instruction. 
The rightmost location (i. e. , the units position) is the first character location to the right of the 
B address to have one of its zone bits not equal to zero. As shown in Figure 8-4, all B -field 
locations to the left of the dividend must contain zeros prior to the divide operation. 

A word mark is required in the leftmost location of the divisor. The dividend may or may 
not contain a word mark. 



Note that the B "field" in a divide operation does not define the B operand but is a group of 
storage locations within which the B operand (the dividend) is contained. 
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ARITHMETIC 



The signs o£ the operands are indicated by the zone bits in the units positions of the divisor 
and dividend. Algebraic sign control is used to determine the sign of the quotient (see Table 
8-7). The sign of the quotient is expressed in its normalized form (minus = 10, plus - 01). The 
sign of the remainder is always the same as that of the dividend (in value if not in bit configu- 
ration); its form is normalized if the sign of the dividend is normalized. 



Table 8-7. Divide Sign Conventions 



Sign of Divisor 


+ 


+ 


- 


- 


Sign of Dividend 


+ 


- 


+ 


- 


Sign of Remainder 


+ 


- 


+ 


- 


Sign of Quotient 


+ 


- 


- 


+ 



Since the presence of a signed digit in the dividend specifies its rightmost location, the 
units position of the dividend must contain a normalized sign and the zone bits of all other 
dividend characters must be zero. 

When division is completed, signed decimal quotient is stored in the leftmost locations of 
the B field; the units position of the quotient is in location B - - 2, where is the 

number of locations in the A field and is the number of locations in the dividend. The signed 
decimal remainder appears in locations B+N^^-1, B+N^^I^-2, etc. through location 

The character location separating the quotient and the remainder is cleared to zero (see Figure 8-4). 

In the following example, the divisor is a two -character field whose rightmost location is 
location 450 and the dividend is a four -character integer whose leftmost location is location 950. 



EASYCODER 

CODING FORM 



3RnRlFM .... 


CARD 

NUMBER 


£ 


R 


LOCATION 


OPERATION 

CODE 


OPERANDS 




^ 1 ^ 








15, 20 


— 1 1 1 ( 1 i 1®^ 


63 . . . . 1 , , , 


' 1 ' 1 








I> 


450,9,50 . . 


. . 


> ■— 1 












. 


i 1 
















h- 


|— 


1 ' ■ ‘ 


' ' 





The contents (+23) of the A field are divided into the contents of the field (+7347) whose 
leftmost location is 950. The rightmost boundary of the dividend is determined by the first 
character location (location 953) to the right of location B whose zone bits are non-zero. This 
units position of the dividend therefore contains the sign of the dividend. 



8-15 





SECTION 8. INSTRUCTIONS 




The quotient (+319) is stored in the leftmost character locations of the B field. The units 
position of the quotient (location 950) is equal to B-N^+N^^-2, or 950-2+4-2. The remainder 
is stored in the rightmost locations of the B field; its leftmost location (location 952) is equal to 
B-N^+N. or 950-2+4; its rightmost location (location 953) is equal to B+N-1, or 950+4-1. The 
result of the operation is shown below. 




FORMAT 



OP CODE 



A ADDRESS 



B ADDRESS 



FUNCTION 

B Th" " ^ algebraically to the signed decimal 

aata in the B field. The result is stored in the B field. 

I decimal data in the A field is added to itself. The result is stored in the 

— specified by the contents of the A-address register (AAR) is 
dded algebraically to the signed decimal data specified by the contents of the B-ad- 
diess register (BAR). The result is stored in the B field. 
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arithmetic 



WORD MARKS 

Format a: The B operand must have a defining word mark. It is this word mark that terminate s 

the operation. The A operand must have a word mark only if it is shorter than the B 

operand. In this case, transmission of data from the A operand stops after the A- 
operand word mark is sensed. If the A field is longer than the B field, the high- 
order characters of the A field that exceed the field length defined by the B -operand 
word mark are not processed. 

F ormat b ; The A operand must have a defining word mark. 

Format c: The B operand must have a defining word mark. The A operand must have a word 

mark only if it is shorter than the B operand. 



TIMING 



F ormat a: T 

T 

F ormat b : T 

Format c : T 

T 



Nj^ + 2 +NT^+ 2 N ]3 memory cycles if no recomplement cycle is required. 
Nj^ + 2+N^+4N|^ memory cycles if a recomplement cycle is required. 
Ni + 2 + 3Ng^ memory cycles. 

3+N-^+2N|^ memory cycles if no recomplement cycle is required. 
3+N^+4N|^ memory cycles if a recomplement cycle is required. 



ADDRESS REGISTERS AFTER OPERATION 





SR 


AAR 


BAR 


F ormat a: 


NXT 




B-Nb 


Format b: 


NXT 


A-Na 


A-Na 


Format c; 


NXT 


Ap~N^ 


Bb-Nb 



NOTES 

1 . 



2 . 



3. 



4. 



The algebraic sign control for the add operation is shown below. 



A -FIELD SIGN 


+ 


— 


+ 


— 


B -FIELD' SIGN-- ■ 


+ 


— 


— 


+ 


TYPE OF ADD 


True 


True 


Comp 


Comp 


SIGN OF RESULT 


Sign of B field 


Normalized sign of A or B 
field, whichever is greater 
(- = 10, + = 01) 



All zone bits in the result field are set to zeros except for the units position 
(i. e. , the sign of the result). 

This instruction treats both operands as signed decimal data. It will pro- 
duce ambiguous results if used to manipulate non-decimal data. Particularly, 
if the four numeric bits of any character have a binary numeric value of 1 2 
or more (octal 14, 15, 16, and 17), the character is treated as if it were 
a zero. The two remaining cases (octal 12 and 13) are unspecified. 

The overflow and zero balance indicators are set by an add operation. 
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EXAMPLE 

Add Bond Deductions to Total Deductions. 

Description Tag 

Bond Deductions BDED 

Total Deductions TDED 



EASYCODER 

COOING FORM 

PROBLEM PROGRAMMER DATE PAGE OF 




FORMAT 



OP CODE A ADDRESS B ADDRESS 




FUNCTION 

Format a : The signed decimal data in the A field is subtracted algebraically from the signed 

decimal data in the B field. The result is stored in the B field. 

Format b : The signed decimal data in the A field is subtracted from itself. The result is 

stored in the A field. If the A-field sign is minus, the result is a minus zero. If 
the A-field sign is plus, the result is a plus zero (with normalized sign). 

Format c : The signed decimal data specified by the contents of the A-address register (AAR) 
is subtracted algebraically from the signed decimal data specified by the contents 
of the B-address register (BAR). The result is stored in the B field. 



WORD MARKS 

Format a : The B operand must have a defining word mark. The A operand must have a word 

mark only if it is shorter than the B operand. In this case, transmission of data 
from the A operand stops after the A-operand word mark is sensed. If the A field 
is longer than the B field, the high-order characters of the A field that exceed the 
field length defined by the B-operand word mark are not processed. 

Format b : The A operand must have a defining word mark. 

Format c; The B operand must have a defining word mark. The A operand must have a word 
mark only if it is shorter than the B operand. 
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ARITHMETIC 



TIMING 



Format a : T 

T 

Format b : T 

Format c: T 

T 



Nj^+2+N^+2N^ memory cycles if recomplement cycle is required. 
Nj_+2+N^+4N-j^ memory cycles if a recomplement cycle is required. 
N^+2+3Ng^ memory cycles. 

3+N^+2N-[^ memory cycles if no recomplement cycle is required. 
3+N^+4N]3 memory cycles if a recomplement cycle is required. 



ADDRESS REGISTERS AFTER OPERATION 



SR AAR BAR 



Format a: 


NXT 




B-Nb 


Format b: 


NXT 


A-Na 


A-N^ 


Format c: 


NXT 


■^p~^w 


Bp-Nb 



NOTES 

1. Algebraic sign control for the subtract operation is summarized below. 



A -FIELD SIGN 


-h 


— 


+ 


— 


■ ■B;-FIELD'.:. SIGN 


H” 


— 


— 




TYPE OF ADD 


Comp 


Comp 


True 


True 


SIGN OF RESULT 


Normalized sign of 
A or B field, which- 
ever is greater 
(- = 10, + = 01) 


Sign of B field 



2. All zone bits in the result field are set to zeros except for the units position 
(i. e. , the sign of the result). 

3. This instruction treats both operands as signed decimal data. It will pro- 
duce ambiguous results if used to manipulate non-decimal data. Partic- 
ularly, if the four numeric bits of any character have a binary numeric 
value of 12 or more (octal 14, 15, 16, and 17), the character is treated 
as if it were a zero. The two remaining cases (octal 12 and 13) are 
unspecified. 

4. The overflow and zero balance indicators are set by a subtract operation. 

EXAMPLE 

Subtract the contents of the five -character fields starting at location 940, 945, 950, 
and 955 from the contents of the eight -character fields starting at locations 648, 
656, 664, and 672. 



PROBLEM PROGRAMMER DATE PAGE OF 



CARD 

NUMBER 


7 




LOCATION 


OPERATION 

CODE 


OPERANDS 




1 2 1 3 4 1 5 


6 


7 


8 , , .14 


. .20 


2', ... 1 .... 1 .... 1 . 1 .. 1 .... 1 ... . . , . 1 


” , j ^ , ,!? 


nr 








S, . . . . 


. , 


-L _L_1 _1_ -L L 1 . u -X. J 










s, . . . . 




_ , . , 1 , , 


. 1 1 




L 








, ■ 1 . . -L_.l . X . . J L-__L^. 


1 1 
— ■ 1 ■ ■ 


- 


- 






. . . . 1 .... 1 .... 1 ■ ... 1 ■> .1 1 1 1 1 i i 1 ■ I L 1 1 1 1 1 


. . 
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BA 



BINARY ADD 



FORMAT 



OP CODE A ADDRESS B ADDRESS 




b. 





FUNCTION 

Format a : The data in the A field is added in binary fashion, character by character, to the 

data in the B field. The result is stored in the B field. 

Format b ; The data in the A field is added character by character, to itself. The result is 
stored in the A field. 

Format c ; The data specified by the contents of the A-address register (AAR) is added char- 
acter by character, to the data specified by the contents of the B -address register 
(BAR). The result is stored in the B field. 



WORD MARKS 



Format a ; The B operand must have a defining word mark. It is this word mark that termi- 
nates the operation. The A operand must have a word mark only if it is shorter 
than the B operand. In this case the transmission of data from the A field stops 
after the A-operand word mark is sensed. If the A field is longer than the B field, 
the high-order characters of the A field that exceed the field length defined by the 
B -operand word mark are not processed. 



Format b ; The A operand must have a defining word mark. 

Format c ; The B operand must have a defining word mark. The A operand must have a word 
mark only if it is shorter than the B operand. 



TIMING 
Format a ; T 
Format b ; T 
Format c: T 



Ni+1+N^+2N^ memory cycles, ^ 
Nj[+l+3Na_ memory cycles. ^ 
2+N^+2N^ memory cycles. ^ 



Add one memory cycle to each of these times if the instruction is being executed in a Type 2201 
processor. 
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ADDRESS REGISTERS AFTER OPERATION 




SR 


AAR 


BAR 


Format a: 


NXT 


> 

1 


B-Nb 


F ormat b: 


NXT 


> 

1 


> 

1 


Format c: 


NXT 


■^p“^W 


B -N^ 
P ° 



NOTES 

1. The overflow and zero balance indicators are not set by a binary add 
operation. 

2. Format b of the BA instruction has the effect of doubling the value stored 
in the A field; i. e. , it shifts the contents of the A field one bit position 
to the left. 



EXAMPLE 

Modify the B address of the instruction tagged B7 by the value stored in the location 
tagged TEN (assuming the use of the two -character addressing mode). 



EASYCODER 

CODING FORM 



PROBLEM 



PROGRAMMER 



DATE 



PAGE OF 



CARO 

NUMBER 


T5 


; LOCATION 


OPERATION 

CODE 


OPERANDS 




1 2 Is 'll 5 


6 


9 ( . .14 


I5| .20 


21, . , , 1 , , , , 1 . . . , 1 , 1 , . 1 . , , , 1 , , , . ] . , , . 1 . . , . 1 


63^ ^ j ^ I 1 i I I®® 




__ 


■ . 1 . ■ . 


M , . , 


...1 ...X 


.L 1 1. ,J. ,J i_.l . 1 i 1 . . i . 



BS 



BINARY SUBTRACT 



FORMAT 



OP CODE A ADDRESS B ADDRESS 





b. 




c. 




FUNCTION 

F ormat a ; Each six-bit character in the A field is converted to its ones complement and added, 
in binary fashion, character by character, to the data in the B field (see page 8-6). 
A. simulated carry is added with the characters in the units position. The result 
is stored in the B field. 

F ormat b : Each six-bit character in the A field is converted to its ones complement and added 

character by character, to itself. A simulated carry is added with the characters 
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in the units position. In effect, this format of the binary subtract instruction re- 
places the contents of the A field with zeros. 

Format c : Each six-bit character specified by the contents of the A-address register (AAR) 

is converted to its ones complement and added, character by character, to the data 
specified by the contents of the B-address register (BAR). A simulated carry is 
added with the characters in the units position. The result is stored in the B field. 



WORD MARKS 

F ormat a ; The word mark associated with the B operand terminates the operation. The A 
operand must have a word mark only if it is shorter than the B operand. In this 
case, transmission of data from the A field stops after the A operand word, mark 
is sensed. If the A operand is longer than the B operand, the characters of the A 
operand that exceed the field length defined by the B operand word mark are not 
processed. 

Format b: The A operand must have a defining word mark. 

Format c: The B operand must have a defining word mark. The A operand must have a word 
mark only if it is shorter than the B operand. 



TIMING 
Format a ; 
Format b : 
Format c: 



T = Nj^ + 1 +N^+2N|^ memory cycles, ^ 
T = N^+l+3Ng^ memory cycles. ^ 

T = 2+N^+2N^ memory cycles. ^ 



ADDRESS REGISTERS AFTER OPERATION 
SR AAR BAR 



F ormat 


a: 


NXT 


> 

i 


B-Nb 


F ormat 


b: 


NXT 


A-N 

a 


A-N 

a 


Format 


c : 


NXT 


A -N 
p w 


B„-K 
P b 



NOTES 

1. The overflow and zero balance indicators are not set by a binary subtract 
operation. 

2. Formats a and c can produce negative results. A negative result is stored 
in the B field in its twos -complement form. In this case, the absolute 
numerical value of the result can be obtained by recomplementing the result 
stored in the B field. 



EXAMPLE 

2^ero the field starting at location TOTAL. 



Add one memory cycle to each of these times if the instruction is being executed in a Type 
2201 processor. 
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EASYCODER 

CODING FORM 



PROBLEM PROGRAMMER DATE PAGE OF 



CARD 

NUMBER 


FI 


w 


LOCATION 


OPERATION 

CODE 


OPERANDS 




1 2 1 3 4 1 5 


6 


7 


8 I 14 


I5| 20 


2 ', . . , 1 . , . . 1 , , , , 1 . 1 , . 1 . . . , . , 1 , , , , 1 


63 , I , , , 1 . 1 , .80 


=ui 






. . L .. . ; 


' J 


TOTAL . . . , . 

1 


. . 1 . . 1 ■ 1 ■ 1 1 . . i_ 1 1.. 1 . 



NOTE: Information bits as well as zone bits are cleared to zero by 
this operation. 



ZA 



ZERO AND ADD 



FEATURES 010 & Oil 



FORMAT 



OP CODE A ADDRESS B ADDRESS 






FUNCTION 

Format a: The data in the A field is transferred, character by character, right to left, to the 

B field. Zone bits in the B field are set to zero in all positions except the units 
position. The sign of the result field is based on the sign of the A field (see note). 
If the high-order character of the A field is transferred before the operation 
terminates, the remaining B-field characters are cleared to zeros. 



Format b: The data in the A field is converted to an all-numeric format; i. e. , the zone bits 

of all positions in the field except the units position are set to zero. The result 
remains in the A field. The sign of the A field is not changed by the operation (see 
note 1). 

Format c: The data specified by the contents of the A-address register (AAR) is transferred 

to the field specified by the contents of the B-address register (BAR). Zone bits 
in the B field are set to zero in all positions except the units position. The sign 
of the result field is based on the sign of the sign of the A field (see note 1). If 
the high-order character of the A field is transferred before the operation termi- 
nates, the remaining B-field characters are cleared to zeros. 



WORD MARKS 

Format a: The B operand must have a defining word mark. The A operand must have a word 

mark only if it is shorter than the B operand. In this case, transfer of data from 
the A operand stops after the A-operand word mark is sensed. If the A field is 
longer than the B field, the high-order characters of the A field that exceed the 
field length defined by the B-operand word mark are not processed. 

Format b: The A operand must have a defining word mark. 
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Format c: The B operand must have a defining word mark. The A operand must have ci word 

mark only if it is shorter than the B operand. 



TIMING 

Formats a, b, and c: 

T = N. + l+N^+N^ memory cycles. 

ADDRESS REGISTERS AFTER OPERATION 
SR AAR BAR 



F or mat 


a: 


NXT 


A-N 

w 


B-N^ 


F or mat 


b: 


NXT 


A-Na 


A-N 

a 


F ormat 


c : 


NXT 


Ap-Nw 


Bp-Nb 



NOTES 

1. A plus sign in the units position of the result field is always expressed in 
its normalized form (01). 

2. B -field punctuation is not changed by this operation. 



EXAMPLE 

Transfer the contents of the field tagged ORATE to the field tagged NRATE, setting 
all zone bits in NRATE (except in the units position) to zeros. 



EASYCODER 

CODING FORM 



PROBLEM PROGRAMMER DATE PAGE OF 



CARD 

NUMBER 


n 

PE 


LOCATION 


OPERATION 

CODE 


OPERANDS 




1 2 1 3 4 1 5 


6 


e. . 1 . . .I'l 


I5| 20 


2'. . . , 1 , , , ^ . 1.11 . J _. l A , 1 1 1^2 


63 , 1 , , , 


' ! '1 






2k 


OR.ATE 1 , VJRATE 1 , . 

















zs 


ZERO AND SUBTRACT 




FEATURES 010 & 01 1 



FORMAT 

OP CODE 




A ADDRESS B ADDRESS 




b. 



c. 





Add one memory cycle to this formula if the instruction is being executed in a Type 2201 
processor. 
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FUNCTION 

Format a: The data in the A field is transferred to the B field with the opposite sign. Zone 

bits in the B field are set to zeros in all positions except the units position. If the 
high-order character of the A field is transferred before the operation terminates, 
the remaining B-field characters are cleared to zeros. 

Format b: The data in the A field is converted to an all-numeric format; i. e. , the zone bits 

of all positions in the field except the units position are set to zero. The result re- 
mains in the A field with its sign reversed. 

Format c: The data specified by the contents of the A-address register (AAR) is transferred 

with the opposite sign to the field specified by the contents of the B-address register 
(BAR). Zone bits in the B field are set to zero in all positions except the units 
position. If the high-order character of the A field is transferred before the oper- 
ation terminates, the remaining B-field characters are cleared to zeros. 

WORD MARKS 

Format a: The B operand must have a defining word mark. The A operand must have a word 

mark only if it is shorter than the B operand. In this case, transfer of data from 
the A operand stops after the A-operand word mark is sensed. If the A field is 
longer than the B field, the high-order characters of the A field that exceed the 
field length defined by the B-operand word mark are not processed. 

Format b: The A operand must have a defining word mark. 

Format c: The B operand must have a defining word mark. The A operand must have a word 
mark only if it is shorter than the B operand. 

TIMING 

Formats a, b, and c: 

T = N^+l+N^+N-j^ memory cycles. ^ 



ADDRESS REGISTERS AFTER OPERATION 
SR AAR BAR 



F or mat a: 


NXT 


A-N 

w 


B-N^ 


F ormat b: 


NXT 


> 

1 


A-N 

ct 


F ormat c : 


NXT 


Ap-N^ 


B -N, 
p b 



NOTES 

1. A plus sign in the units position of the result field is always expressed in its 
normalized form (01). 

Z. B-field punctuation is not changed by this operation. 



Add one memory cycle to this formula if the instruction is being executed in a Type 2201 
processor. 
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EXAMPLE 



Change the sign of the data in the field tagged PROFIT. 



EASYCODER 

CODING FORM 



PROGRAMMER DATE PAGE OF. 



CARD 

NUMBER 




R 

l< 


LOCATION 


OPERATION 

CODE 


OPERANDS 








7 


8 _ 1 , , _ 14 


15, _ , 20 


1 .... 1 .... 1 .... ... 1 .... 1 .62 


63 . 1 , 80 


I 


- 


_ 


- . ■ 1 , ■ ■ 




PROFIT , , 


— 1 ^1 ■ . . I 1 . . . . 1 ■ ■ . . 



mX MULTIPLY 



FORMAT 



OP CODE A ADDRESS B ADDRESS 






FUNCTION 

Format a : The signed decimal integer in the A field is multiplied by the signed decimal integer 

in the leftmost locations of the B field. The product is stored, right -justified, in 
the B field. 



F ormat b : The signed decimal integer in the A field is multiplied by the signed decimal integer 

in the leftmost locations of the field specified by the contents of the B-address reg- 
ister (BAR). The product is stored, right -justified, in the B field. 

Format c : The signed decimal integer in the field specified by the contents of the A-address 

register (AAR) is multiplied by the signed decimal integer in the leftmost locations 
of the field specified by the contents of BAR. The product is stored, right-justified, 
in the B field. 



WORD MARKS 
Formats a, b, and c: 

Word marks are required in the high-order locations of both the A and B fields. 
All other B-field locations must not contain word marks. 



TIMING 

Formats a, b, and c: 

Types 201-1, 201-2, and 1201 processors; 
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T Nj^+5+2Ng^+2Z]^g^+5Nj^j, -Z^j.+s(N2^-Z^-g^)+Z(Na^-Z^g^) -Z^^j,) memory cycles. 

TYPE 2201 PROCESSOR: 

T = Ni+8+2Na+2Z(^+5N^r-Z^^+SUM(Na-Zt^)+3(Na-Zta)(N^r-Z^r) memory cycles. 

Representative times for the Types 201-1, 201-2, 1201, and 2201 processors are 
given in note 7. 



ADDRESS REGISTERS AFTER OPERATION 




SR 


AAR 


BAR 


Format a: 


NXT 


A-Na 


B-Nb 


Format b: 


NXT 


A-Na 


Bp-Nb 


F ormat c : 


NXT 


Ap-Na 


Bp-Nb 



NOTES 

1. The A address of a Decimal Multiply instruction specifies the units position 
of the multiplicand. The B address specifies a location which is N^+l lo- 
cations to the right of the multiplier, since the B field must contain the 
multiplier plus enough additional locations (to the right of the multiplier) to 
provide for the development of the product. Thus, the total number of 
character locations in the B field must be one greater than the sum of the 
number of characters in the multiplicand and the multiplier. For example, 
in a multiplication operation involving a 3-character multiplier and a 5- 
character multiplicand, 9 positions (5+3+1) must be provided in the B field. 

2. Algebraic sign control for the multiply operation is shown below. The sign 
of the product is expressed in its normalized form (- = 10, +=01). 



Sign of Multiplicand 


+ 


- 


+ 


- 


Sign of Multiplier ; 


+ 


- 


- 


+ 


Sign of Product 


+ 


+ 


- 


- 



3. The product is stored (right -justified) in the entire B field, with the unused 
high-order positions of the B field cleared to zeros. As a result of the 
operation, the multiplier (initially stored in the B field) is destroyed. 
Therefore, if the multiplier is to be used more than once, it should be 
preserved in another storage field. 

4. The zero balance indicator is turned ON if the product of the multiply oper- 
ation is equal to zero; otherwise, the indicator is turned OFF by the operation. 

5. This instruction treats both operands as signed decimal data. It will pro- 
duce ambiguous results if used to manipulate non-decimal data. Particularly, 
if the four numeric bits of a character have a binary numeric value of 1 2 or 
more (octal 14, 15, 16, or 17), the character is treated as if it were a 
zero. The two remaining cases (octal 12 and 13) are unspecified. 

6. This instruction is a standard feature on all processors but the Type 201, 
on which it is not available. 

7. Listed below are representative multiply times (in microseconds) for the 
Type 201-1, 201-2, 1201, and 2201 processors. It is assumed that the 
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three -character addressing mode is used and that each multiplier digit 
has the median value of 4. 5. 



TYPE 201-1 AND 201-2 MULTIPLY, TIMES (MICROSECONDS) 
NO. OF CHARACTERS. IN MULTIPLICAND 



1 2 3 4 5 



NUMBER OF 


1 


51 


68 


85 


102 


119 




2 


74 


104 


134 


164 


194 




3 


97 


140 


183 


226 


269 


IlijiliiSWHIl 


4 


120 


176 


232 


288 


344 




5 


143 


212 


281 


350 


419 



• TYPE 


1201 MULTIPLY TIMES (MICROSECONDS) 






OF CHARACTERS IN MULTIPLICAND 








1 


2 


3 


4 


5 


NUMBER OF : 


1 


39. 8 


52. 5 


65. 3 


78 


90. 8 


|||||i|||||i||f|| 


2 


57 


79. 5 


102 


124. 5 


147 




3 


74. 3 


106. 5 


138. 8 


171 


203. 3 


MULTIPLIER 


4 


91.5 


133. 5 


1 75. 5 


217. 5 


259. 5 




5 


108. 8 


160. 5 


212. 3 


264 


315. 8 









1 TYPE 2201 MULTIPLY TIMES (MICROSECONDS) 




OF CHARACTERS IN MULTIPLICAND 




1 1 2 3 4 5 



NUMBER OF 


1 


28 


36 


44 


52 


60 






2 


39 


53 


67 


81 


95 






3 


50 


70 


90 


1 10 


130 




MULTIPLIER J ^ 


4 


61 


87 


113 


139 


165 




lillilBlilili 


5 


72 


104 


136 


168 


200 





EXAMPLE 

Multiply the five -character field tagged CAND by the three -character field whose 
rightmost character location is six (5 + 1) less than the location tagged PROD. 
Store the result, right -justified, in PROD. 

EASYCODER 

COOING FORM 

PROBLEM PROGRAMMER DATE PAGE OF, 



CARD 


T 










NUMBER 




R 


LOCATION 


CODE 


OPERANDS 







ARITHMETIC 



D 



DIVIDE 



FORMAT 



OP CODE A ADDRESS B ADDRESS 




b. 




FUNCTION 



Format a: The signed decimal integer in the field whose leftmost location is B is divided by 

the signed decimal integer in the A field. The quotient is stored in the leftmost 
locations of the B field; the remainder is stored in the rightmost locations of the B 
field (see page 8-13). 

Format b: The signed decimal integer in the field whose leftmost location is specified by the 

contents of the B -address register (BAR) is divided by the signed decimal integer 
in the A field. The quotient is stored in the leftmost locations of the B field; the 
remainder is stored in the rightmost locations of the B field (see page 8-13). 



Format c: The signed decimal integer in the field whose leftmost location is specified by the 

contents of the B -address register (BAR) is divided by the signed decimal integer 
in the field specified by the contents of the A-address register (AAR). The quotient 
is stored in the leftmost locations of the B field; the remainder is stored in the 
rightmost locations of the B field (see page 8-13). 



WORD MARKS 
Formats a, b, and c: 

The A operand (the divisor) must contain a word mark. The B field may contain 
a word mark. 



TIMING 

Formats a, b, and c: 

TYPES 201 -1, 201-2, AND 1201 PROCESSORS: 

T = N-+4+2N_ memory cycles if divisor = 0. 

1 3 ^ 

T = N- + 17. 5+4. 5N^+15. 5Zj^+12. 5N^^+1 5N^(N^^j-N^+Z j ^) memory cycles if 
(Na- Z 1 a) (Ndd) divisor;^0. 

T = N-+7+4Ng^ memory cycles if (Na“ Z j a) > (^dd) • 

TYPE 2201 PROCESSOR: 

T = Ni+7 + 2Ng^ memory cycles if divisor = 0. 

T = N.+9 + 2Z + 5N3^+3Z2^j+Nq(15N^-2Z|3^+18. 25) memory cycles if 
(Ng^-Z2a)< (^dd~^ld^ divisor;^0. 
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T = N-+9+2N^+2N^^ memory cycles if N^>N^j^ and (Na-Z 2 ^)> 

T = N^ + 1 O+Ng^+SNjj^^ memory cycles if Na> N^^^j and (Na-Zjg^) > (Ndd-^ld)- 

Representative divide times for the Type 201 -1, 201 -2, 1201, and 2201 processors 
are given in note 10. 



ADDRESS REGISTERS AFTER OPERATION (WHEN DIVISOR IS NOT EQUAL TO ZERO) 
SR AAR BAR 



F or mat a: 


NXT 


> 

1 


B-N^+Ndd-3 


F or mat b : 


NXT 


A-N^ 


Bp-Na+Ndd-3 


Format c: 


NXT 


Ap-Na 


Bp-Na+Ndd-3 



= Tens position of quotient field 



When the divisor is equal to zero, the contents of the address registers are un- 
specified (see note 1). 



NOTES 

1 . 

2 . 



3. 

4. 



5. 



6 . 



If the divisor is equal to plus or minus zero, the overflow indicator is turned 
ON, division is not performed, and no memory locations are changed. 

The length of the B field is determined by adding 1 to the sum of the number 
of character locations in the divisor and the dividend (B -field length =1 + 
length of divisor + length of dividend). 

The A field (divisor) can be signed or unsigned; if it is unsigned, the divisor 
is assumed to be positive. 

The dividend must contain a normalized sign (- = 10, + = 01) in the units 
position. The sign bits of all other characters in the dividend must be zeros. 
The proper signing of the dividend is therefore insured if the dividend is 
moved into the B field by a Zero and Add instruction (see page 8-23). 

All high-order locations of the B field which are not occupied by the dividend 
must contain zeros when division begins. These zeros can be automatically 
inserted if the Zero and Add instruction is used to move the dividend into 
the B field as mentioned above. 

The sign of the quotient follows algebraic sign rules as shown below. The 
sign of the remainder is the original sign of the dividend. 



Sign of divisor j 


+ 


+ 


- 


- 




+ 


- 


+ 


- 


^ 


+ 


- 


+ 


- 


Sign of quotient 


+ 


- 


- 


+ 



This instruction treats both operands as signed decimal data. It will pro- 
duce ambiguous results if used to manipulate non-decimal data. Particularly, 
if the four numeric bits of a character have a binary numeric value of 1 2 
or more (octal 14, 15, 16, or 17), the character is treated as if it were a 
zero. The two remaining cases (octal 12 and 13) are unspecified. 

This instruction is a standard feature on all processors but the Type 201, 
on which it is not available. 
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9. Listed below are representative divide times (in microseconds) for the 
Type 201-1, 201 -2, 1201, and 2201 processors. It is as sumed that the 
processor is in the three -character addressing mode in all cases. 





201 


DIVIDE TIMES (MICROSECONDS) 




NUMBER OF CHARACTERS IN DIVIDEND 






1 


2 


3 


4 


5 




1 


83 


138 


193 


248 


303 


||||||j|i|||^ 


2 


44 


117 


202 


287 


372 


IN 


3 


52 


52 


151 


266 


381 


DIVISOR 


4 


60 


60 


60 


185 


330 




5 


68 


68 


68 


68 


219 



( i 201 DIVIDE TIMES (MICROSECONDS) 












1 


2 


3 4 


5 


NUMBER OF • 


1 


62 


103. 5 


145 186 


227 


Igiiiil^CTERS 


2 


34. 5 


88 


151.5 215 


279 


ilBiftSiSIIB 


3 


40. 5 


40. 5 


94 199.5 


286 




4 


46. 5 


46. 5 


52.5 139 


247. 5 


. 


5 


52. 5 


52. 5 


52.5 52.5 


164 



2201 'DIVIDE ITMES (MiOROSEC + 

■,NUMBEli/OF Cflykl^Ct'ERS .iN'DIViDEND ; 






1 


2 


3 


4 


5 


NUMBER OF 


1 


54 


88 


121 


154 


187 


CHARACTERS 


2 


22 


74 


123 


170 


219 


IN 


3 


24 


26 


94 


158 


221 


DIVISOR 


4 


26 


28 


30 


114 


193 




5 


28 


30 


32 


34 


134 



EXAMPLE 

Divide the four -character integer whose leftmost location is location 1000 by the 
three -character field whose rightmost location is location 500. Store the quotient 
in the leftmost locations of the field at 1000, and store the remainder in the right- 
most locations of this field. 

(number of characters in divisor) = 3 

Ndd (number of characters in dividend) = 4 

B (B address) = 1000 

Units position of quotient (B 2) = 1000-3+4-2 = location 999 
Units position of remainder (B+N^^-1) = 1000+4-1 = location 1003 
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• EXTRACT 

• HALF ADD 

• SUBSTITUTE 

• COMPARE 

• BRANCH 

• BRANCH ON CONDITION TEST 

• BRANCH ON CHARACTER CONDITION 

• BRANCH IF CHARACTER EQUAL 

• BRANCH ON BIT EQUAL 
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EXT 



EXTRACT 
(Logical Product) 



FORMAT 



OP CODt A ADDRESS B ADDRESS 




FUNCTION 

Format a : The data in the A field is combined bit-by-bit with the data in the B field, according 

to the following rules. The result is stored in the B field. 



BIT IN 
; A FIELD 

II 


L BIT IN 

L B FIELD 


BIT IN 

RESULT FIELD 


1 


1 


1 


1 


0 


0 


0 


1 


0 


0 


0 


0 



Format b : The data in the A field is combined bit-by-bit with the data specified by the con- 

tents of the B-address register (BAR), according to the rules stated above. The 
result is stored in the B field. 

Format c : The data specified by the contents of the A-address register (AAR) is combined 

bit-by-bit with the data specified by the contents of BAR, according to the rules 
stated above. The result is stored in the B field. 



WORD MARKS 
Formats a, b, and c: 

A word mark is required for the shorter of the two operands. The operation 
terminates when this word mark is sensed. 



TIMING 

F ormats a, b, and c: 

T = N.+1+3N memory cycles. ^ 

1 W ' ' 



Add one memory cycle to this formula if the Extract instruction is being executed in a Type 
2Z01 processor. 
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ADDRESS REGISTERS AFTER OPERATION 




SR 


AAR 


BAR 


Format a: 


NXT 


A-Nw 


B-N 

w 


Format b: 


NXT 




p w 


F ormat c : 


NXT 


A -N 
p w 


B -N 
p w 



EXAMPLE 

Remove all zone bits in the field tagged BASE by combining the contents of BASE 
with the contents of the field tagged CON. Each character in CON must have the 
following format: 

Bit position B A 8 4 2 1 
Contents 0 0 1111 

EASYCODER 

CODING FORM 



PROGRAMMER DATE PAGE OF 



CARD 

NUMBER 


FI 

I 




LOCATION 


OPERATION 

CODE 


OPERANDS 




1 2 |3 4l 9 


6 


7 


e 1 14 


15, . 20 


21. . . , 1 . . . . 1 , . , , 1 , i . . 1 , . , , 1 , .--i.. 1 1^^ 


63, , 8° 










EXT 


CON.BASE 


' ' 1 ' ' ' ' ‘ ‘ ‘ ‘ ' - 



HA 



HALF ADD 
(Exclusive Or) 



FORMAT 



OP CODE A ADDRESS B ADDRESS 




FUNCTION 

Format a: The data in the A field is combined bit-by-bit with the data in the B field, accord- 

ing to the following rules. The result is stored in the B field. 



BIT IN 
A FIELD 


BIT IN 
B FIELD 


BIT IN 

rjtrcfTTT tr'TtPT "Pk 

JLm4 JL JE? jLi* iI iJ 


1 


1 


0 


1 


0 


1 


0 


1 


1 


0 


0 


0 
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F ormat b : The data in the A field is combined bit-by-bit with the data specified by the con- 

tents of the B -address register (BAR), according to the rules stated above. The 
result is stored in the B field. 

Format c : The data specified by the contents of the A-address register (AAR) is combined 

bit-by-bit with the data specified by the contents of BAR, according to the rules 
stated above. The result is stored in the B field. 



WORD MARKS 
Formats a, b, and c: 

A word mark is required for the shorter of the two operands. The operation 
terminates when this word mark is sensed. 



TIMING 

Formats a, b , and c: 

T = Ni+1+3N memory cycles. ^ 
1 w ^ ^ 



ADDRESS REGISTERS AFTER OPERATION 




SR 


AAR 


BAR 


Format a: 


NXT 




B-N 

w 


Format b: 


NXT 


A-N 

w 


B -N 
p w 


F o-rmat c : 


NXT 


A -K,r 

p w 


B -N„, 
p w 



EXAMPFE 

Clear all the data bits in the field tagged SEVEN to zeros by combining the con- 
tents of SEVEN with the contents of the field tagged TOO. Do not change the zone 
bits in SEVEN. (The data contents of SEVEN and TOO are identical. ) 



EASYCODER 

COOING FORM 



. _ PROGRAMMER 



CARD 

NUMBER 


1 


f 

R 

K 


LOCATION 


OPERATION j 
CODE 




1 2 1 3 4l 5 




7 


8. . 1 . . .14; 


15, , . ,20 


21, , , . I , , , , 1 


. . 1 .1 






■ .._i . _ 


HA ^ 1 ^ 


TOO. SEVEN . 



OPERANDS 



Add one memory cycle to this formula if the Half Add instruction is being executed in a Type 
2201 processor. 
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SST 



SUBSTITUTE 



FORMAT 



OP CODE A ADDRESS B ADDRESS VARIANT 




FUNCTION 



Format a: The single character specified by the A address is compared bit-by-bit with the 

variant character and is moved to the location specified by the B address, accord- 
ing to the following rules: 

1. The A-character bit is transferred to the B address if the corresponding 
variant bit = 1 . 



2. The B -character bit is preserved if the corresponding variant bit = 0. 

Format b; The single character specified by the A address is compared bit-by-bit with the 
variant character specified in a previous instruction and is moved to the lo- 
cation specified by the B address, according to the rules stated above. 

Format c: The single character specified by the A address is compared bit-by-bit with the 

variant character specified in a previous instruction and is moved to the location 
specified by the contents of the B-address register (BAR), according to the rules 
stated above. 



Format d: The single character specified by the contents of the A-address register (AAR) 

is compared bit-by-bit with the variant character specified in a previous instruc- 
tion and is moved to the location specified by the contents of BAR, according to 
the rules stated above. 



WORD MARKS 
Formats a, b, c, and d: 

Word marks are not required in either field. 



TIMING 

Formats a, b, c, and d: 

T = N^+4 memory cycles. ^ 



Add one memory cycle to this formula if the Substitute instruction is being executed in a 
Type 2201 processor. 
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ADDRESS REGISTERS AFTER OPERATION 
SR AAR BAR 



Format a: 


NXT 


A-1 


B-1 


F ormat b: 


NXT 


A-1 


B-1 


F ormat c : 


NXT 


A-1 


Bp-l 


F ormat d: 


NXT 


Ap-1 


Bp-1 



NOTE 

This instruction can be coded only in formats a. and d. when programming for 
the Type 201 or 201-1 processor. 



EXAMPLES 

1. Move the zone bits from the location tagged STET to the location tagged 
STET +20. A variant character of octal 60 provides the required variant 
bit configuration (i. e. , 110 000). 



EASYCODER 

CODING FORM 

PROBLEM PROGRAMMER DATE PAGE OF 



CARD 

NUMBER 


1 

i 


1 


LOCATION 


OPERATION 

CODE 


OPERANDS 




1 2 1 3 4l S 


6 


7 


9 1 . .14 


I5i . . . .20 


• 1 . . . . 1 . . . . 1 . 1 1 . 1 . . . . 1 . I . , 1 


63, . 1 . , . 1 . 1 . .00 


-Lb 






. . 1 . . 




§Le:t.,S,TET+,2iZf.„6(Z^, . , , , , . , , 


_ , , , . 1 . 



2. Move the numeric portion of the character at location 256 to location 656. 
A variant of octal 17 provides the required variant bit configuration 
(i. e. , 001 111). 



EASYCODER 

CODING FORM 



PROBLEM 



PROGRAMMER 



DATE 



PAGE OF 



CARO 

NUMBER 


1 


1 


LOCATION 


OPERATION 

CODE 


OPERANDS 




1 2 1 3 4| 5 


6 




8 1 ... 14 


<5| . , . ,20 


2', . . , 1 . . , . 1 . . . . 1 . 1 1 , 1 , , , , 1 , , , , 1 , , , , 1 . , , , 1 


63 , 1 , , , , , , .80 


' 1 '1 


1 


1 






256,6, Sfoj 17, , , 




T 1 — 1 


■ 


■ 











Q I COMPARE 



FORMAT 

OP CODE A ADDRESS B ADDRESS 
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FUNCTION 

Format a: The data in the B field is compared bit-by-bit to the data in the A field. The com- 

parison turns on indicators that can be interrogated by subsequent Branch instruc- 
tions. The indicators are reset by the next Compare instruction. 

Format b; The data specified by the contents of the B-address register (BAR) is compared 
bit-by-bit with the data in the A field. This operation turns on indicators which 
can be tested by subsequent Branch instructions. The indicators are reset by the 
next Compare instruction. 

Format c: The data specified by the contents of BAR is compared bit-by-bit to the data in 

the field specified by the contents of the A-address register (AAR). The com- 
parison turns on indicators that can be interrogated by subsequent Branch instruc- 
tions. The indicators are reset by the next Compare instruction. 



WORD MARKS 
Formats a, b, and c : 

The word mark associated with the B operand terminates the operation. The A 
operand must have a word mark only if it is shorter than the B operand. In this 
case, transmission of data from the A field stops after the A-operand word mark 
is sensed, and the remaining characters of the B operand are compared to zeros. 
If the A operand is longer than the B operand, the characters of the A operand that 
exceed the field length defined by the B-operand word mark are not processed. 



TIMING 

Formats a, b, and c ; 

T = N^+2+N^+N-[^ memory cycles. ^ 



ADDRESS REGISTERS AFTER OPERATION 




SR 


AAR 


BAR 


Format a: 


NXT 




B-N^ 


F or mat b: 


NXT 


A-N 

w 


®p-Nb 


Format c: 


NXT 


A„-N 
P w 


Bp-Nb 



NOTES 

1. All characters that can appear in storage can be compared. The ascending 
order of characters is listed in Appendix B. 

2. Both fields must have exactly the same bit configurations to be equal. For 
example, plus zero is not equal to minus zero. 

3. Comparison results and associated branch conditions are listed bn page 8-40. 



1 



Add two memory cycles to this formula if the instruction is executed in a Type 2201 processor. 
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COMPARISON RESULT 


BRANCH CONDITION 


B<A 


Low Compare 


B=A 


Equal Compare 


B<A 


Low or Equal Compare 


B>A 


High Compare 


BM 


Unequal Compare 


B>A 


High or Equal Compare 



EXAMPLE 

Compare Item Number to 4000. If Item Number equals 4000, continue the program 
in sequence; otherwise, branch to location NITEM. 

Description 

Item Number 

4000 



Tag 

ITEM 

CON4 



EASYCODER 

CODING FORM 



PROBLEM PROGRAMMER DATE PAGE OF. 



CARD 

NUMBER 


7 

1 


1 


LOCATION 


OPERATION 

CODE 


OPERANDS 




1 .2 1 3 ,4i 5 


6 


7 


8. 1 . .14 


I5| , . . 20 


1 .... 1 .... 1 . I .. 1 .... i .... 1 .... 1 .... 1 ,62 


63. , 1 . , . . 1 , , 1 , 80 


1 1 
. 1 






. . 1 . . 


c, 


C0N4,,IT.EM , , . , , . , 




1 

■ ■ ■ 1 ■ 1 




_ 





bC.T, , , 


^^ITEM,,A6 


-L-l . . . . 1 1 , . , 



B I BRANCH 



FORMAT 



OP CODE A ADDRESS B ADDRESS VARIANT 




FUNCTION 

The Branch instruction causes the program to branch to the location specified 
by the A address and to store the contents of the sequence register (SR) in theB- 
address register (BAR). It is used to interrupt normal program sequence and 
to continue the program at any desired point, without testing for specific con- 
ditions. Thus, this instruction is frequently referred to as an "unconditional 
branch. " 

WORD MARKS 

Word marks are not affected by this instruction. 



TIMING 

T = N^+2 memory cycles. ^ 



Add one memory cycle to this formula if the Branch instruction is being executed in a Type 2201 
processor. 
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ADDRESS REGISTERS AFTER OPERATION 
SR AAR BAR 

JI (A) A NXT 



NOTE 

The address bits of the A address are placed in AAR during the extraction of this 
instruction. When the instruction is executed, the entire contents of AAR specify 
the address to which the program branches. Also, the entire contents of SR are 
stored in BAR during the execution phase. 



EXAMPLE 



Select the next instruction from the location tagged SUB6. 



EASYCODER 

CODING FORM 



PROBLEM PROGRAMMER DATE PAGE OF, 



CARD 

NUMBER 




J 

R 

K 


LOCATION 


OPERATION 

CODE 


OPERANDS 

1 




1 , 2 1 3 ,4 1 5 


6 


7 


8. . 1 . . ,14 


, , , ,20 


. . ... ... 1 , , , . 1 , . . , 1 , . , , , 1 , , 1 ,62 






— 


_ 


1 . I . 




, , , 





BCT BRANCH ON CONDITION TEST 



FORMAT 



OP CODE A ADDRESS B ADDRESS VARIANT 




FUNCTION 

Format a; The variant character specifies a condition indicator or a SENSE switch to be 

tested. If the condition being tested is present, the program branches to the lo- 
cation specified by the A address and the contents of the sequence register (SR) 
are stored in the B-address register (BAR). If the condition specified by the 
variant character is not present, the program continues in sequence. Tables 8-8 
and 8-9 list the valid variant characters and the conditions they test. 

Format b ; If the condition specified by the previous variant character is present, the pro- 
gram branches to the location specified by the contents of the A-address register 
(AAR) and the contents of SR are stored in BAR. If the condition being tested is 
not present, the program continues in sequence. Tables 8-8 and 8-9 list the valid 
variant characters and the conditions they test. 
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Table 8-8. SENSE Switch Test Conditions for BCT Instruction 



Vafiant Character 
(Octal) 




00 


Unconditional 


01 


SENSE Switch 1 On 


02 


SENSE Switch 2 On 


03 


SENSE Switches 1 and 2 On 


04 


SENSE Switch 3 On 


05 


SENSE Switches 1 and 3 On 


06 


SENSE Switches 2 and 3 On 


07 


SENSE Switches 1, 2, and 3 On 


10 


SENSE Switch 4 On 


11 


SENSE Switches 1 and 4 On 


12 


SENSE Switches 2 and 4 On 


13 


SENSE Switches 1, 2, and 4 On 


14 


SENSE Switches 3 and 4 On 


15 


SENSE Switches 1, 3, and 4 On 


16 


SENSE Switches 2, 3, and 4 On 


17 


SENSE Switches 1, 2, 3, and 4 On 


20 


Unconditional 


21 


SENSE Switch 5 On 


22 


SENSE Switch 6 On 


23 


SENSE Switches 5 and 6 On 


24 


SENSE Switch 7 On 


25 


SENSE Switches 5 and 7 On 


26 


SENSE Switches 6 and 7 On 


27 


SENSE Switches 5, 6, and 7 On 


30 


SENSE Switch 8 On 


31 


SENSE Switches 5 and 8 On 


32 


SENSE Switches 6 and 8 On 


33 


SENSE Switches 5, 6, and 8 On 


34 


SENSE Switches 7 and 8 On 


35 


SENSE Switches 5, 7, and 8 On 


36 


SENSE Switches 6, 7, and 8 On 


37 


SENSE Switches 5, 6, 7, and 8 On 



NOTE: When testing for a multiple SENSE switch condition, a branch occurs only 
if all of the specified conditions are met. 



8-42 









LOGIC 



Table 8-9. Indicator Test Conditions for BCT Instruction 



' 

Variant Character 
(Octal) 




41 


B<A (Low Compare) 


42 


B=A (Equal Compare) 


43 


B<A (Low or Equal Compare) 


44 


B >A (High Compare) 


45 


B?^A (Unequal Compare) 


46 


B>A (High or Equal Compare) 


47 


Unconditional 


50 


Overflow 


51 


Overflow or B<A 


52 


Overflow or B=A 


53 


Overflow or B<A 


54 


Overflow or B>A 


55 


Overflow or Bi^A 


56 


Overflow or B>A 


57 


Unconditional 


60 


Zero Balance 


61 


Zero Balance or B<A 


62 


Zero Balance or B=A 


63 


Zero Balance or B<A 


64 


Zero Balance or B>A 


65 


Zero Balance or B^A 


66 


Zero Balance or B>A 


67 


Unconditional 


70 


Overflow or Zero Balance 


71 


Overflow or Zero Balance or B< A 


72 


Overflow or Zero Balance or B=A 


73 


Overflow or Zero Balance or B<A 


74 


Overflow or Zero Balance or B >A 


75 


Overflow or Zero Balance or B^A 


76 


Overflow or Zero Balance or B>A 


77 


Unc onditional 



NOTE: When testing for a multiple indicator condition, a branch occurs if any one 
of the specified conditions is met. 
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WORD MARKS 
Formats a and b: 

Word marks are not affected by this instruction. 



TIMING 

Formats a and b: 

T = N^+2 memory cycles. ^ 

ADDRESS REGISTERS AFTER OPERATION 





SR 


AAR 


BAR 




Format a: 


JI (A) 


A 


NXT 


BRANCH 




NXT 


A 


=P 


NO BRANCH 


Format b: 


JI (Ap) 


A 


NXT 


BRANCH 




NXT 




Sp 


NO BRANCH 



NOTES 

1. If the overflow indicator is tested and an overflow condition exists, the 
indicator is automatically reset as a result of being tested. In all other 
cases, the indicator tested is not reset as a result of the test. 

2. The comparison indicators are: 

a. set by the Compare instruction; 

b. stored (and cleared ) by the Store Variant and Indicators 
instruction; 

c. restored by the Restore Variant and Indicators instruction; 

d. restored by the Resume Normal Mode instruction; and 

e. stored when an external interrupt occurs. 

3. The address bits of the A address (if any) are placed in AAR during the ex- 
traction of this instruction. If the instruction causes a branch (i.e. , if the 
condition being tested is present), the entire content s of AAR specify the 
address to which the program branches when the instruction is executed. 
Also, the entire contents of SR are stored in BAR during the execution 
phase of the instruction. 

4. Consider the variant character in its six-bit form V^ V 5 V 4 V 2 V 2 V 2 . The 
following chart may be used to determine the variant character to be used 
in a BCT instruction. 



Add two memory cycles to this formula if the instruction is executed in a Type 220 1 processor. 
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'll 1 








'’z 


LJB 


00 = Test SENSE 
Switches 1 
through 4 


SENSE 
Switch 4 


SENSE 
Switch 3 


SENSE 
Switch 2 


SENSE 
Switch 1 


01 = Test SENSE 
Switches 5 
through 8 


SENSE 
Switch 8 


SENSE 
Switch 7 


SENSE 
Switch 6 


SENSE 
Switch 5 


1 = Test 
Zero 
Balance, 
Overflow, 
or Compare 


Zero 

Balance 


Overflow 


High 

Compare 


Equal 

Compare 


Low 

Compare 



5. SENSE switches 5 through 8 are included as a standard feature with the Type 
2201 processor and are not available with the Model 200 or 1200 processors. 



6. This instruction can be coded only in format a. when programming for the 
Type 201 or 201-1 processor. 



EXAMPLE 

Subtract CREDIT from TOTAL and test for a zero balance. If this condition exists 
branch to BZRO; otherwise continue the program in sequence. 



EASYCODER 

CODING FORM 



PROBLEM PROGRAMMER DATE PAGE OF 



CARD 

NUMBER 


T 




LOCATION 


OPeRATION 

CODE 


OPERANDS 




1 2 |3 4l 5 


6 


7 


8. . 1 . . .14 


IS, . , . .20 


2', . , , 1 . . . . 1 . , . , 1 . 1 . , 1 , , . . ] . . , 1 ..L i_ , . 1 . . . . 1 .- 3 ^ 


. 1 , 1 .... 1 ... .80 


' 1 '1 










C.RE 0,1 ,T.,, total. , , , , , , , , , 


, . 1 , , . , 1 , . , 1 . 


-Ll 






- ■ ■ 1 ■ ■ ■ 


B^CT 


fiZ.RO, ,i6.0 , . . 1 , . . 1. ... 


1 .--t 1 i 1 . . ,.L_L i_.l ^ 



BCC I branch on character condition 



FORMAT 



OP CODE A ADDRESS B ADDRESS VARIANT 




FUNCTION 

Format a : The single character specified by the B address is examined for the condition 

specified by the variant character. If the condition is present, the program branches 
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to the location specified by the A address, and the contents of the sequence reg- 
ister (SR) are stored in the B -address register (BAR). If the condition is not 
present, the program continues in sequence. The valid variant characters and the 
condition each represents are listed in Tables 8-10 and 8-11. 

F or mat b : The single character specified by the B address is examined for the condition 

specified by the variant character of a previous instruction. If the condition is 
present, the program branches to the location specified by the A address, and the 
contents of SR are stored in BAR. If the condition is not present, the program 
continues in sequence. The valid variant characters and the condition each rep- 
resents are listed in Tables 8-10 and 8-11. 

Format c : The single character specified by the contents of BAR is examined for a condition 

specified by the variant character of a previous instruction. If the condition is 
present, the program branches to the location specified by the A address, and the 
contents of SR are stored in BAR. If the condition is not present, the program 
continues in sequence. The valid variant characters and the condition each re- 
presents are listed in Tables 8-10 and 8-11. 

Format d : The single character specified by the contents of BAR is examined for a condition 

specified by the variant character of a previous instruction. If the condition is 
present, the program branches to the location specified by the contents of the A- 
address register (AAR), and the contents of SR are stored in BAR. If the condition 
is not present, the program continues in sequence. The valid variant characters 
and the condition each represents are listed in Tables 8-10 and 8-11. 

Table 8-10. Basic Test Conditions for BCC Instruction 



— p--...., 

Variant Character 
(Octal) 


i C|iaracter Condition 


00 


Unconditional 


02 


The B bit of the character at B is 1. 


06 


The character at B contains a negative sign (the 
B and A bits are 10). 


10 


The character at B contains either a word mark 
or a record mark (the word-mark bit is 1). 


12 


The B bit is 1 and the word-mark bit is 1. 


16 


The character at B contains a negative sign and 
the word-mark bit is 1. 


20 


The character at B contains either an item mark 
or a record mark (the item-mark bit is 1). 


22 


The B bit is 1 and the item-mark bit is 1. 


26 


The character at B contains a negative sign and 
the item-mark bit is 1. 


30 


The character at B contains a record mark (the 
word-mark and item-mark bits are 11). 


32 


The character at B contains a record mark and 
the B bit is 1 . 


36 


The character at B contains a record mark and a 
negative sign. 
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Series 200 processors which are equipped with Feature 010 or Oil (see Figure 1-5) 
can interpret any bit configuration of the variant character, ranging from octal 00 
to octal 77. The valid variant characters which can be interpreted with this option 
are shown in Table 8-11 and expanded in Appendix B. 

Table 8-11. BCC Test Conditions with Advanced Programming Feature 



Variant Character 




xo 




No condition. 


XI 




The A bit of the character at B is 1. 


X2 




The B bit of the character at B is 1. 


X3 




The B and A bits of the character at B are 1 1 . 


X4 




The B and A bits of the character at B are 00. 


X5 




The character at B contains a positive sign (the 
B and A bits are 01). 


X6 




The character at B contains a negative sign (the 
B and A bits are 10). 


X7 




The B and A bits of the character at B are 11 
(same as X3 above). 


OX 




No condition. 


IX 




The word-mark bit of the character at B is 1 
(either a word mark or a record mark is present). 


2X 




The item-mark bit of the character at B is 1 
(either an item mark or a record mark is present). 


3X 




The character at B contains a record mark. 


4X 




The character at B contains no punctuation mark. 


5X 




The character at B contains a word mark. 


6X 




The character at B contains an item mark. 


7X 




This is a special case; see note 2. 


NOTES: 1. An X represents any octal digit. If both octal digits specify "no 

condition" (i. e. , 00 ), the branch occur s unconditionally . If only 
one digit is 0, the branch occurs if the condition specified by the 
other digit is met. If both octal digits specify conditions , the branch 
occurs if both conditions are met. The variant character 7X is an 
exception to these rules, as described in note 2. 


2. The Type 201 and 201-1 processors interpreta 7X variantas if it 
were a 3X(i.e., branch to the A address if the character at B 
contains a record mark and the condition specified by X is met). 


All other processors interpret the 7X variant as follows: 


a. 


If Xis 0, 


the branch is an unconditional branch. 


b. 


If X is any digit other than 0, the branch occurs if 
either the condition specified by the rightmost digit is 

met or the character at B contains a word mark. 
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WORD MARKS 
Formats a, b, c, and d : 

Word marks are not affected by this instruction. 

TIMING 

Formats a, b, c, and d : 

T = Nj^+4 memory cycles. ^ 



ADDRESS REGISTERS AFTER OPERATION 





SR 


AAR 


BAR 




F ormat a: 


JI (A) 


A 


NXT 


BRANCH 




NXT 


A 


B-1 


NO BRANCH 


Format b: 


JI (A) 


A 


NXT 


BRANCH 




NXT 


A 


B-1 


NO BRANCH 


Format c: 


JI (A) 


A 


NXT 


BRANCH 




NXT 


A 


Bp-1 


NO BRANCH 


F ormat d: 


JI (A ) 


Ap 


NXT 


BRANCH 




NXT 




B„-l 

p 


NO BRANCH 



NOTES 

1. If the octal configuration of the variant character is 00, or 70, the branch 
is unconditional. 

2. The address bits of the A address (if any) are placed in AAR during the 
extraction of the BCC instruction. If the instruction causes a branch (i. e. , 
if the condition being tested is present), the entire contents of AAR specify 
the address to which the program branches when the instruction is executed. 
Also, the entire contents of SR are placed in BAR during the execution phase. 

3. This instruction can be coded only in formats a. and d. When program- 
ming for the Types 201 or 201-1 processor. 

EXAMPLE 

If the location tagged END contains a negative sign, branch to the location tagged 
TTFIELD. Otherwise, continue the program in sequence. 

EASYCODER 

CODING FORM 



PROBLEM PROGRAMMER __DATE PAGE OF. 



CARD 

NUMBER 


F 


m 

1 


LOCATION 


OPERATION 

CODE 


OPERANDS 




1 2 1 3 4 1 5 




7 


8 . , 14 


15, . , , ,20 


‘ 1 ■ . . . 1 ■ . . . 1 ■ 1 ■ . , 1 


. 1 . , . , 1 . , 1 , 80 




1 

■ 


1 

■ 


. . 1 . . . 




NF.l.EL,D.,.E.N.D,.Cf6 


i . 1 ... 1 1 ■ 



Add one memory cycle to this formula if the instruction is being executed in a Type 2201 
processor. 
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LOGIC 




FUNCTION 

Format a : The single character specified by the B address is compared to the variant charac- 

ter. If the bit configurations of the two characters are equal, the program branches 
to the location specified by the A address, and the contents of the sequence register 
(SR) are stored in tbe B-address register (BAR). If the bit configurations are 
unequal, the program continues in sequence. 

Format b : The single character specified by the B address is compared to the variant charac- 

ter specified in a previous instruction. If the bit configurations of the two charac- 
ters are equal, the program branches to the location specified by the A address, 
and the contents of SR are stored in BAR. If the bit configurations are Unequal, 
the program continues in sequence. 

Format c : The single character specified by the contents of BAR is compared to the variant 

character specified in a previous instruction. If the bit configurations of the two 
characters are equal, the program branches to the location specified by the A ad- 
dress, and the contents of SR are stored in BAR. If the bit configurations are 
unequal, the program continues in sequence. 

Format d : The single character specified by the contents of BAR is compared to the variant 

character specified in a previous instruction. If the bit configurations of the two 
characters are equal, the program branches to the location specified by the con- 
tents of the A-address register (AAR), and the contents of SR are stored in BAR. 

If the bit configurations are unequal, the program continues in sequence. 

WORD MARKS 

Formats a, b, c, and d : 

A word mark in the location tested has no effect on the instruction. 

TIMING 

Formats a, b, c, and d: 

T = Nj^+4 memory cycles. ^ 

Add one memory cycle to this formula if the instruction is being executed in a Type 2201 
processor. 
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SECTION 8. INSTRUCTIONS 



ADDRESS REGISTERS AFTER OPERATION 





SR 


AAR 


BAR 




Format a: 


JI (A) 


A 


NXT 


BRANCH 




NXT 


A 


B-1 


NO BRANCH 


F ormat b: 


JI (A) 


A 


NXT 


BRANCH 




NXT 


A 


B-1 


NO BRANCH 


Format c: 


JI (A) 


A 


NXT 


BRANCH 




NXT 


A 


Bp-l 


NO BRANCH 


Format d: 


JI (A ) 


Ap 


NXT 


BRANCH 




NXT 


Ap 


Bp-1 


NO BRANCH 



NOTES 

1. This instruction can be coded only in formats a. and d. when programming 
for the Type 201 or 201-1 processor. 

2. The address bits of the A address (if any) are placed in AAR during the ex- 
traction of the BCE instruction. If the instruction causes a branch (i. e. , 

if the condition being tested is present), the entire contents of AAR specify 
the address to which the program branches when the instruction is executed. 
Also, the entire contents of SR are placed in BAR during the execution phase 



EXAMPLES 

1. Determine if the character stored in the location tagged LABEL+3 is equal 
to 6. If so, branch to the location tagged P6; otherwise continue the pro- 
gram in sequence. 



EASYCODER 

CODING FORM 



PROBLEM 



PROGRAMMER 



DATE 



PAGE OF. 



CARD 

NUMBER 


FI 

i 


R 


LOCATION 


OPERATION 

CODE 


OPERANDS 




1 2 1 3 4 1 5 


6 


7 


8 , 14 


15, 20 


21 1 t 1 .... 1 .... 1 1 .... 1 .... 1 


63, , , 1 , ,80 






,_L . . 


ftCE 


P6 j \.A,BEL + 3,j 6 . 


J L 1- 1 1 i. -I 



2. Determine if any character position in the seven-character field tagged 

PART contains the letter Q. If so, branch to the location tagged RETRO; 
otherwise continue the program in sequence. 

EASYCODER 

COOING FORM 



PROBLEM PROGRAMMER DATE PAGE OF 



CARD 

NUMBER 






LOCATION 


OPERATION 

CODE 


OPERANDS 




1 2 |3 4l 5 


6 


7 


8 1 14 


15, .20 


21 1 1 , , 1 , 1 1 . 1 .... 1 1 ... I . 1 .. 1 .... 1 


83, , 1 1 , , , ,80 


“TT 








B,CE 


RE.TR.O,,.P.A.RT,,.9. . . , 


. . 1 . . . I 1 1 . . . 1 1 . . . 


.1.1 








B,CE 




.1. 1 ,1 L—1 1 1 J 1 1 L_1 ^ 1 


— ■ — 1 — ■ — hH 
. 1 1 








B.CE 




,, 1 1 , 


1 1 








BCE 




.. r .... 1 .... 1 ... . 


■■■■■f ^ r" 

- 1 1 








BCE 




. 1 . ■ 1 , A . ± -1 ■»_ .^ _1 i . .1. — 


1 1 








B,CE 




-X -J- -1 -1 i-. X ..J ^ L. 














_l l_-l 1 . . T__l. .J ^ 1 
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LOGIC 



BBE 


BRANCH ON BIT EQUAL 




FEATURE 010 



FORMAT 



OP CODE A ADDRESS B ADDRESS VARIANT 




FUNCTION 



Format a : The single character specified by the B address is combined bit-by-bit with the 

variant character, according to the rules shown below. If the result (the logical 
product) is not equal to zero, the program branches to the location specified by 
the A address, and the contents of the sequence register (SR) are stored in the B- 
address register (BAR). If the result is equal to zero, the program continues in 
sequence. 



Bit in 

B Character 


Bit 'in 
Variant Cha 


racter 


Bit in 


1 


1 


1 


1 


0 


0 


0 


1 


0 


0 


0 


0 



F ormat b ; The single character specified by the B address is combined bit-by-bit with the 

variant character specified in a previous instruction, according to the rules shown 
above. If the result is not equal to zero, the program branches to the location 
specified by the A address, and the contents of SR are stored in BAR. If the result 
is equal to zero, the program continues in sequence. 



Format c : The single character specified by the contents of BAR is combined bit-by-bit with 

the variant character specified in a previous instruction, according to the rules 
shown above. If the result is not equal to zero, the program branches to the lo- 
cation specified by the A address, and the contents of SR are stored in BAR. If 
the result is equal to zero, the program continues in sequence. 

F ormat d : The single character specified by the contents of BAR is combined bit-by-bit with 

the variant character specified in a previous instruction, according to the rules 
shown above. If the result is not equal to zero, the program branches to the lo- 
cation specified by the contents of the A-address register (AAR), and the contents 
of SRI are stored in BAR. If the result is equal to zero, the program continues in 
sequence. 
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SECTION 8. INSTRUCTIONS 



WORD MARKS 
Formats a, b , c, and d : 

Word marks are not tested by this instruction and have no effect on the operation. 



TIMING 

Formats a, b, c, and d: 

T = N|^+4 memory cycles. ^ 



ADDRESS REGISTERS AFTER OPERATION 





SR 


AAR 


BAR 




Format a: 


JI (A) 


A 


NXT 


BRANCH 




NXT 


A 


B-1 


NO BRANCH 


Format b: 


JI (A) 


A 


NXT 


BRANCH 




NXT 


A 


B-1 


NO BRANCH 


Format c: 


JI (A) 


A 


NXT 


BRANCH 




NXT 


A 


Bp-1 


NO BRANCH 


Format d: 


JI (Ap) 


Ap 


NXT 


BRANCH 




NXT 




Bp-1 


NO BRANCH 



NOTES 

1. The logical product formed by this instruction is tested but is not stored . 
Main memory locations are not disturbed by this operation. 

Z. The address bits of the A address (if present) are placed in AAR during 

the extraction of the instruction. If the instruction causes a branch (i. e. , 
if the logical product does not equal zero), the entire contents of AAR 
specify the address to which the program branches when the instruction is 
executed. Also, the entire contents of SR are placed in BAR during the 
execution phase. 



EXAMPLE 

Branch to the location tagged BBIT if the character at the location tagged MAR 
contains a "1" in the B-bit position. Otherwise, continue the program in sequence. 

EASYCODER 

CODING FORM 



PROBLEM PROGRAMMER DATE PAGE OF 



CARD 

NUMBER 


I 


I 


LOCATION 


OPERATION 

CODE 


OPERANDS 




1 2 1 3 4| 5 


6 


Q 


8 1 . . .14 


I5| 20 


21. . . . 1 . . . . 1 , . , , 1 . L ■ . 1 , . , , 1 . , , . 1 , , , , 1 , , . , 1 


63, , , , , , . I , , , . 1 , , , 80 


ca 






. ■ L ■ . . 






_L L_J L._,J 1 -L 1 . . , 



Add one memory cycle to this formula if the instruction is being executed in a Type 2201 
processor. 
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CONTROL 



• SET WORD MARK 
•SET ITEM MARK 

• CLEAR WORD MARK 
•CLEAR ITEM MARK 

• HALT 

•NO OPERATION 

• MOVE CHARACTERS TO WORD MARK 

• LOAD CHARACTERS TO A- FIELD WORD MARK 

• STORE CONTROL REGISTERS 

• LOAD CONTROL REGISTERS 

• CHANGE ADDRESSING MODE 

• CHANGE SEQUENCING MODE 
•EXTENDED MOVE 

• MOVE AND TRANSLATE 

• MOVE ITEM AND TRANSLATE 

• LOAD INDEX/ BARRICADE INDICATOR 

• STORE INDEX/BARRICADE INDICATOR 





SECTION 8. INSTRUCTIONS 



sw 



SET WORD MARK 



FORMAT 



OP CODE A ADDRESS B ADDRESS 






FUNCTION 

Format a: A word mark is set at the location specified by each address. The data and item- 

mark bits at each location are undisturbed. 

Format b: A word mark is set at the location specified by the A address. The data and item- 

mark bits at this location are undisturbed. 

Format c: Word marks are set at the locations specified by the contents of the A- and B-ad- 

dress registers (AAR and BAR). The data and item-mark bits at each location 
are undisturbed. 



WORD MARKS 
Formats a, b, and c : 

Word marks are set as described above. 

TIMING 

Formats a, b, and c; 

T " Ni + 3 memory cycles. ^ 

ADDRESS REGISTERS AFTER OPERATION 





SR 


AAR 


BAR 


F or mat a: 


NXT 


A-1 


B-1 


Format b: 


NXT 


A-1 


A-1 


F ormat c : 


NXT 




Bp-l 



Add one memory cycle to this formula if the instruction is being executed in a Type 2201 proc- 
essor. Subtract one memory cycle from this formula if the instruction is being executed in a 
Type 1201 processor in format a. 
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CONTROL 



NOTE 

The extraction of this instruction when coded in format a. automatically terminates 
when the last character of the B address is loaded into BAR. Therefore, a word 
mark is not required in the location following the B address. 



EXAMPLE 



Set a word mark in location 435. 



EASYCODER 

CODING FORM 



PROBLEM PROGRAMMER DATE PAGE OF 



CARD 

NUMBER 






LOCATION 


OPERATION 

CODE 


OPERANDS 




1 2 1 3 4l 5 


6 


7 


8. . 1 . . .14 


I5| 20 


2', ... 1 .... 1 .... 1 1 1 62 


83 , 1 .80 










sw. ! ! 


435 , 


, . . 1 1 L_. 1 1 J _l.. ^-L_ 1 ■ ■ . 



SI 



SET ITEM MARK 



FORMAT 



OP CODE A ADDRESS B ADDRESS 






FUNCTION 

F ormat a ; An item mark is set at the location specified by each address. The data and 
word-mark bits at each location are undisturbed. 

F ormat b ; An item mark is set at the location specified by the A address. The data and word- 
mark bits at this location are undisturbed. 

Format c : Item marks are set at the locations specified by the contents of the A- and B -ad- 

dress registers (AAR and BAR). The data and word-mark bits at each location 
are undisturbed. 



WORD MARKS 
Formats a, b, and c : 

Word marks are not affected by this instruction. 
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SECTION 8. INSTRUCTIONS 



TIMING 

Formats a, b, and c: 

T = N^+3 memory cycles. ^ 

ADDRESS REGISTERS AFTER OPERATION 





SR 


AAR 


BAR 


Format a: 


NXT 


A-1 


B-1 


F ormat b: 


NXT 


A-1 


A-1 


Format c: 


NXT 


Ap-1 


Bp-1 



NOTE 

The extraction of this instruction when coded in format a. automatically terminates 
when the last character of the B address is loaded into BAR. Therefore, a word 
mark is not required in the location following the B address. 



EXAMPLE 



Set item marks in the locations tagged ENT and ENT+80 



EASYCODER 

CODING FORM 



PROBLEM PROGRAMMER DATE PAGE OF 



CARD 

NUMBER 


FI 

p 


1 


LOCATION 


OPERATION 

CODE 


OPERANDS 




1 a |3 4l 5 


6 




8 , .14 


15, ,20 


2', , . , 1 , , . . 1 1 . i i-i l._ _L . 1 . , . , 1 


1 1 . 1 . I ] , , , , 1 , i_ 


I [ 








SX 


ENT,EMT>a0 


■ -i 1 ■ . . ■ 1 U . . ■ 1 L. ■ i 1 


r 1 M 















cw 



CLEAR WORD MARK 



FORMAT 



OP CODE A ADDRESS B ADDRESS 





b. 




c. 




Add one memory cycle to this formula if the instruction is being executed in a Type 2201 proc- 
essor. Subtract one memory cycle from this formula if the instruction is being executed in a 
Type 1201 processor in format a. 
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CONTROL 



FUNCTION 

Format a ; The locations specified by the A and B addresses are cleared of word marks. The 
data and item-mark bits at these locations are undisturbed. 

Format b ; The word mark at the location specified by the A address is cleared. The data and 
item-mark bits at this location are undisturbed. 

Format c : Word marks are cleared at the locations specified by the contents of the A- and 

B-address registers (AAR and BAR). The data and item-mark bits at these lo- 
cations are undisturbed. 



WORD MARKS 
Formats a, b, and c : 

Word marks are cleared as defined above. 

TIMING 

Formats a, b, and c ; 

T = Nj^ + 3 memory cycles. ^ 

ADDRESS REGISTERS AFTER OPERATION 





SR 


AAR 


BAR 


Format a: 


NXT 


A-1 


B-1 


Format b: 


NXT 


A-1 


A-1 


Format c: 


NXT 


A -1 


B -1 






P 


P 



EXAMPLE 

Clear the word marks at locations 400 and 435. 



EASYCODER 

COOING FORM 



PROBLEM PROGRAMMER DATE PAGE OF. 



CARD 

NUMBER 


i 


1 


LOCATION 


OPERATION 

CODE 


OPERANDS 




1 2 |3 4l 5 


6 


7 


8. . 1 . . .14 


>5| . . . 20 


. 1 . . . . 1 . . . . 1 . . 1 . r . . . 1 . . . . 1 .62 


63^ 1 1 1 I 1 I I ( 1 8^ 




- 


u 


— ^ l_ . . . 




^ 0 ^ — , I . , . 1 . , , , 1 , , , , , 


. . 1 . , . 1 



Add one memory cycle to this formula if the instruction is being executed in a Type 2201 
processor. 
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SECTION 8. INSTRUCTIONS 



Cl 



CLEAR ITEM MARK 



FORMAT 



OP CODE A ADDRESS B ADDRESS 





b. 




FUNCTION 

Format a: Item marks are cleared from the locations specified in the A and B addresses. 

The data and word-mark bits at these locations are undisturbed. 

Format b: The item mark at the location specified by the A address is cleared. The data 

and word-mark bits at this location are undisturbed. 

Format c: Item marks are cleared at the locations specified by the contents of the A- and 

B -address registers (AAR and BAR). The data and word-mark bits at these lo- 
cations are undisturbed. 



WORD MARKS 
Formats a, b„ and c : 

Word marks are not affected by this instruction. 



TIMING 

Formats a, b, and c : 

T = Nj^+3 memory cycles. ^ 

ADDRESS REGISTERS AFTER OPERATION 





SR 


AAR 


BAR 


Format a: 


NXT 


A-1 


B-1 


F ormat b; 


NXT 


A-1 


A-1 


Format c: 


NXT A -1 

P 


B -1 
P 



EXAMPLE 

Clear the item mark in location REC. 

^Add one memory cycle to this formula if the instruction is being executed in a Type 2201 
processor. 
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CONTROL 



EASYCODER 

CODING FORM 

PROBLEM PROGRAMMER DATE _______ PAGE OF 




FORMAT 




FUNCTION 

Format a : This instruction causes the machine to stop. Pressing the RUN button causes the 

program to resume with the next instruction in sequence. 

Format b: The contents of the sequence register (SR) are stored in the B-address register 

(BAR); the A address of the instruction is transferred to SR; then the machine 
stops. Pressing the RUN button causes the program to resume with the instruc- 
tion specified in the A address. This format is usually referred to as a "halt 
and branch" instruction. 

Format c: This instruction causes the machine to stop. Pressing the RUN button causes the 

program to resume with the next instruction in sequence. The address portions 
can be used to indicate control information such as a halt identification number 
(see note 2). 

Format d: This instruction causes the machine to stop. Pressing the RUN button causes the 

program to resume with the next instruction in sequence. The address portions 
and the variant character can be used to indicate control information such as halt 
identification number (see note 2). 

WORD MARKS 

Formats a, b, c, and d ; 

Word marks are not affected by this instruction. 

TIMING 

Formats a, b, c, and d: 
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SECTION 8. INSTRUCTIONS 





T = Ni+2 


memory cycles. 


, 1 


ADDRESS REGISTERS AFTER OPERATION 




SR 


AAR 


BAR 


Format a; 


NXT 


A„ 


B 






P 


P 


F ormat b: 


JI (A) 


A 


NXT 


Format c; 


NXT 


A 


B 


F ormat d; 


NXT 


A 


B 



NOTES 

1 . If a Halt instruction (in any format) is executed during a peripheral 
transfer, the transfer continues until it is completed. 

2. Formats c. and d. are useful when a program contains a number of 
halts. By assigning a number or symbol in the A and B addresses to 
each halt, the programmer can later identify a particular halt by dis- 
playing the contents of AAR and/or BAR. Although the contents of the 
variant register cannot be displayed through the console or control 
panel, format d. can be used to store a variant character which can sub- 
sequently be used by the program. 

3. The Halt op code is a "privileged" op code that has special significance 
when the Type 1201 or 2201 central processor is equipped with the Storage 
Feature (see Appendix E). 

4. This instruction can be coded only in formats a. , b. , and c. when pro- 
gramming for the Type 201 or 201-1 processor. 



EXAMPLES 

1. Stop the machine and specify that when the RUN button is pressed, the 
next instruction will be selected from the location tagged RES. 



EASYCODER 

CODING FORM 



PROBLEM 



PROGRAMMER 



DATE 



PAGE OF. 



CARD 

NUMBER 


1 

i 


R 

K 


LOCATION 


OPERATION 

CODE 


OPERANDS 




1 2 1 3 4l 5 


6 


7 


8. , , , 


15, , , . ,20 


. . .1. . J 1 , , , , 1 ,62 


63 , , , , , , , , 80 


LU 






l,_i . 1 


H . . . . 


RE.S. . 1 . , , . 1 . . . . 1 , . , 1 , , . , j . . . , 1 , 


__1 l_l .- x-., ■ 1 .... 1 ... ■ 



2. Identify the halt at the end of a job as follows; 

A address =9 
B address =9 

EASYCODER 

CODING FORM 



PROBLEM PROGRAMMER DATE PAGE OF 



CARO 

NUMBER 


1 

i 


f 


LOCATION 


OPERATION 

CODE 


OPERANDS 




1 ^2 1 3 ,4l 5 


6 


7 


8 _ 1 _ _ _I4 


15, , . _ 20 


1. ..... 1 . 1 . 1 J , I . . , .... 1 .62 


63_ 1 1 , I , I 1 , , . , 1 , 1 . 


j ' j 






...... 


H . . 


9.J.9, . . . 1 .... 1 , 


, , 1 . , , . 1 . . . . 1 , . . . 



Add two memory cycles to this formula if the instruction is being executed in a Type 22’01 
processor. 
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CONTROL 



NOP 



NO OPERATION 



FORMAT 

OP CODE 



A ADDRESS B ADDRESS 



FUNCTION 

This instruction performs no operation. This op code can be substituted for the 
op code of any instruction to make that instruction ineffective. 



WORD MARKS 

Program operation resumes at the next op code identified by a word mark. 



TIMING 

T = 3 memory cycles. ^ 

ADDRESS REGISTERS AFTER OPERATION 

SR AAR BAR 

NXT A B 

P P 



NOTES 

1 . 



2 . 



This instruction is commonly used in program modification to cause the 
machine to skip over specific instructions. 

Information appearing in an address portion of an instruction for which 
the NOP instruction is substituted is not loaded into the associated operand 
address register. 



EXAMPLE 

Reserve one storage location for an operation code such as Branch (B). When the 
op code B is inserted, the NOP instruction will be modified to branch to location 
SWX. 



EASYCODER 

COOING FORM 



PROBLEM PROGRAMMER DATE PAGE .OF. 



CARD 

NUMBER 


i 


i 


LOCATION 


OPERATION 

CODE 


OPERANDS 




1 2 |3 4l 5 


6 


7 


6. . 1 . . .14 


>5| . . . .20 


2'. ... 1 .... 1 .... 1 .... 1 1 .... 1 .62 


. 1 . . . 1 . . 1 , SO 




1 


1 


. ^ 1 ■ . . 




. . . , . 


1 . i . . . 1 1 . . . . 1 , . . . 



Add one memory cycle to this formula if the instruction is being executed in a Type 2201 proc- 
essor. Subtract one cycle from the formula if the instruction is executed in a Type 1201 
processor. 
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SECTION 8. INSTRUCTIONS 



MCW 



MOVE CHARACTERS TO 
WORD MARK 



FORMAT 



OP CODE A ADDRESS B ADDRESS 




b. 




FUNCTION 

Format a: The data and item-mark bits in the A field are moved to the B field. 

F ormat b : The data and item-mark bits in the A field are moved to the field specified by the 
contents of the B-address register (BAR). 

Format c : The data and item-mark bits in the field specified by the contents of the A-address 

register (AAR) are moved to the field specified by the contents of BAR. 

WORD MARKS 
Formats a, b, and c : 

A word mark is required in the shorter of the two fields. The operation terminates 
when this word mark is sensed. 



TIMING 



Formats a, 


b, and c: 








T = Nj^+1+2N^ memory 


cycles. ^ 


ADDRESS REGISTERS AFTER OPERATION 




SR 


AAR 


BAR 


F ormat a: 


NXT 


A-N^ 


B-N^ 


F ormat b: 


NXT 


A-N^ 


®p“^w 


Format c: 


NXT 


Ap-Nw 


®p“^w 



NOTE 

Item marks initially stored in B -field locations will be cleared if the corresponding 
A-field characters do not include item marks. 



Add one memory cycle to this formula if the instruction is being executed in a Type 2201 
processor. 
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CONTROL 



EXAMPLE 

Move the following A fields and store them in sequential B fields as shown. 



Description 


A field 


B field 


Unit Number 


150-155 


800-805 


Rack Number 


160-168 


806-814 


Part Number 


173-180 


815-822 


Pin Number 


185-187 


823-825 



EASYCODER 

CODING FORM 



CARD 

NUMBER 


F 

I 


1 


LOCATION 


OPERATION 

CODE 


OPERANDS 


t OF 


1 .2 1 3 .41 5 


6 


7 






2'. ... 1 .... 1 .... J .... 1 ...... . , , ,62 


63, , , . , . . ,80 


■UH 










l.d.7^&,25. , , , 




HHI 






. . 1 . . . 








■M 






. ■ 1 ■ ■ 








■n 






.-j ■ . ■ 








■n 




_ 


—1 ■ 1 ■ ■ ■ 




— ' — * — ' — ' — 1 — ' — 1 — 1 — 1 — 1 — » — 1 — » 1 1 » . » ■ < » . ■ ■ 1 ■ I I . 1 . . . ■ 1 . 1 , , 1 , 


. ■ 1 . » . ■ 1 ■ . ■ . 1 . . . ■ 



LCA 



LOAD CHARACTERS TO 
A-FIELD WORD MARK 



FORMAT 



OP CODE A ADDRESS B ADDRESS 




FUNCTION 

F ormat a : The data and punctuation bits in the A field are transferred to the B field. 

F ormat b : The data and punctuation bits in the A field are transferred to the field specified by 
the contents of the B-address register (BAR). 

Format c: The data and punctuation bits in the field specified by the contents of the A-address 

register (AAR) are transferred to the field specified by the contents of BAR. 

WORD MARKS 
Formats a, b, and c : 

The A operand must have a defining word mark. The operation terminates when 
this word mark is transferred to the B field. 
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TIMING 



F or mats a, 


b, and c : 








T = N|^ + l+2Ng^ memory 


cycles . ^ 


ADDRESS REGISTERS AFTER OPERATION 




SR 


AAR 


BAR 


F ormat a: 


NXT 


A-N^ 


B-Na 


F ormat b : 


NXT 


A-N^ 


Bp-Na 


F ormat c : 


NXT 


Ap-Na 


Bp-Na 



NOTES 

1 . This instruction (in any format) is the only instruction that always moves 
both a field and its defining punctuation mark. 

2. A record mark appearing in the A field terminates the operation. 

3. All punctuation (word marks, item marks, and record marks) initially 
stored in B-field locations will be cleared if the corresponding A-field 
characters do not include identical punctuation. 

4. The B address must never fall within the A field. The A address may fall 
within the B field, however, if desired. 



EXAMPLE 



Move both the data bits and the defining word mark of the field tagged TWX to the 
field tagged RATE. 



EASYCODER 

CODING FORM 



PROBLEM PROGRAMMER DATE PAGE OF- 



CARD 

NUMBER 


1 


m 


LOCATION 


OPERATION 

CODE 


OPERANDS 




1 Z 1 3 4 1 5 


6 


7 


8 , 14 


15, 20 


21. . . . 1 , , . , i ^ , .. 1 ^ j. . , . 1 , , . , 1 , , . . 1 . . . . 1 


63 , 1 . , , , , , 80 


' r 








LCA 


TWXjRATE. . , . . , , 


1 ■ -■ 1 1,1 1 L_1 .11, 








. . 1 . . . 


1 ■ . . . 




. . 1 1 1 1 1 1 i . . ■ 1 I ■ ■ 1 



Add one memory cycle to this formula if the instruction is executed in a Type 2201 processor. 
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SCR I STORE CONTROL REGISTERS 



FORMAT 



OP CODE A ADDRESS B ADDRESS VARIANT 






FUNCTION 

F ormat a : The contents of the control memory register specified by the variant character 

are stored in the field whose units position is defined by the A address of this 
instruction. The method of storing these contents depends on the addressing mode 
being used, as shown in Table 8-12. 



Table 8-12. Control Register Contents Stored by SCR Instruction 



Addressing Mode 


Amount of Control Register Stored 


Two - Character 




Low-order two characters (12 bits). 


Three -Character 




Low-order 15 bits; the high-order three 
bits of the field specified by the A address 
are cleared to zeros. 


F our-Character 




The entire 18 bits (three characters) of 
the control register. 


NOTE: All bit positions not required to address the largest memory 

address in a user's system are set to zeros in the A field. 



The valid variant characters and the control register each character represents 
are listed in Table 8-13. 

F ormat b : The contents of the control memory register specified by the variant character in 

a previous instruction are stored in the field whose units position is defined by 
the A address of this instruction. The number of bits stored depends on the ad- 
dressing mode being used, as shown in Table 8-12. The valid variant characters 
and the control register each character represents are listed in Table 8-13. 

F ormat c : The contents of the control memory register specified by the variant character in 

a previous instruction are stored in the field whose units position is defined by 
the contents of the A-address register (AAR). The number of bits stored depends 
on the addressing mode being used, as shown in Table 8-12. The valid variant 
characters and the control register each character represents are listed in 
Table 8-13. 
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Table 8-13. Control Registers Stored by SCR Instruction 



Variant Character 
(Octal) 


: Control Register 


Variant Character 
(Octal) 


Control Register 


01 


CLCl 


21 


CLC4 


02 


CLC2 


22 


CLC5 


03 


CLC3 


23 


CLC6 


05 


CLCl ' 


25 


CLC4' 


1 1 


SLCl 


31 


SLC4 


12 


SLC2 


32 


SLC5 


13 


SLC3 


33 


SLC6 


15 


SLCl ' 


35 


SLC4' 


64 


CSR 


70 


BAR 


66 


EIR 


76 


HR 


67 (see note 2) 


AAR 


77 


SR 



WORD MARKS 
Formats a, b, and c: 

A-operand punctuation neither affects nor is affected by this instruction. 



TIMING 

Formats a, b, and c : 

T = Nj^+5 memory cycles. ^ 

ADDRESS REGISTERS AFTER OPERATION 
Formats a, b , and c: 

SR AAR BAR 

NXT Ap Bp 



NOTES 

1. If AAR is specified by the variant character (octal 67), the previous address 
in AAR (not the A address retrieved from this instruction) is stored in the 
location specified by the A address. 

2. The control memory register actually designated by the variant character 

6 7g is a work register (not AAR). During the extraction of an SCR or LCR 
instruction (see below), AAR is used to reference the main memory. 

Prior to this, the previous contents of AAR are stored in the work reg- 
ister; at the end of the instruction, the contents of the work register are 
restored in AAR. 

3. This instruction can be coded only in format a. when programming for the 
Type 201 or 201-1 processor. 



Add two memory cycles to this formula if the instruction is executed in a Type 2201 processor. 
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EXAMPLE 



Store the contents of BAR in the A address of the Branch instruction tagged EXIT. 
(The processor is assumed to be in the three-character addressing mode. ) 



EASYCODER 

CODING FORM 



PROBLEM ^ PROGRAMMER DATE PAGE OF 



CARD 

NUMBER 


1 


I 


LOCATION 


OPERATION 

CODE 


OPERANDS 




DBEItlB 


□ 


a 


. 1 . . 


I5| . , . .20 




63, , 1 , , , ,80 


elt 






hhhi 






_ 


■ 1 ■! 






SUB 


acR 


, 
















1 1 








. ■ 1 ■ ■ ■ 


, ( . 




, , , , , , 


1 1 
. 1 , 1 








i 






. 1 . 1 








1 / 








_ 


__ 


EXIT 




0 . . 1 , . . , 1 . . I . 1 . , , ^ 1 ... . 1— . ■■■ ] L 


1 _1_.J i__l 1 . .1 . ■ ■ ■ U 



LCR 


LOAD CONTROL REGISTERS 




FEATURE on 



FORMAT 



OP CODE A ADDRESS B ADDRESS VARIANT 




c. 




FUNCTION 

Format a ; The contents of the field specified by the A address are loaded into the control 

register specified by the variant character. The contents of the A field is another 
main memory address. The method of loading this address into the specified 
control register depends on the addressing mode being used, as shown in Table 8-14. 



Table 8-14. Control Register Contents Loaded by LCR Instruction 



Addressing Mode 



Amount of Memory Address Loaded 



Two -Character 



Two-character (12-bit) address is loaded 
into the low-order two character locations 
of the register. All other bits in the reg- 
ister (if any) are not disturbed (i. e. , the 
bank bits are protected). 



Three -Character 



F our - Character 



15-bit address is loaded into the low-order 
15-bit locations of the register. All other 
bits in the register (if any) are not dis- 
turbed (i. e. , the sector bits are protected). 

18-bit address is loaded into the register. 
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Variant characters and their associated control registers are the same as those 
specified for the Store Control Registers instruction (see Table 8-13). 

F ormat b : The contents of the field specified by the A address are loaded into the control 

register specified by the variant character in a previous instruction. The method 
of loading the contents of this field (another main memory address) depends on the 
addressing mode being used, as shown in Table 8-14. Variant characters and 
their associated control registers are the same as those specified for the Store 
Control Registers instruction. 

Format c : The main memory address specified by the contents of the A-address register 

(AAR) is loaded into the control register specified in a previous instruction. The 
method of loading this address into the specified register depends on the addressing 
mode being used, as shown in Table 8-14. Variant characters and their associated 
control registers are the same as those specified for the Store Control Registers 
instruction. 



WORD MARKS 
Formats a, b, and c: 

A-operand punctuation neither affects or is affected by this instruction. 

TIMING 

Formats a, b, and c : 

T = Ni+5 memory cycles. ^ 

ADDRESS REGISTERS AFTER OPERATION 
F ormat s a, b, and c: 



SR 


AAR 


BAR 




NXT 


A 




VARIANT = 67g 


NXT 


A 

P 


A 


VARIANT = 70g 


A 




=P 


VARIANT = 77g 


NXT 


Ap 


Bp 


ALL OTHERS 



NOTES 

1. If SR is specified by the variant character (77g), the next instruction is 
selected from the location specified by the A address of the Load Control 
Registers instruction. In all other cases, the program continues in sequence. 

2. This instruction can be coded only in format a. when programming for 
the Type 201 or 201-1 processor. 



Add two memory cycles to this formula if the instruction is being executed in a Type 2201 
processor . 
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The LCR op code is a "privileged" op code which has special significance 
when used with a Type 1201 or 2201 processor equipped with the Storage 
Protect Feature (see Appendix 2. ) 



EXAMPLE 



Load the address stored in the location tagged SUBl into the change sequence 
register (CSR). 



EASYCODER 

COOING FORM 



PROGRAMMER DATE 



CARD 

NUMBER 

1 2 |3 4l 5 


II 

6 ■ 


1 LOCATION 

' 8 . . 1 . 14 


1 OPERATION 
CODE 

15, , 20 


OPERANDS 

21, , , , I i ; : ^ 






-- 


_i . 1 ■ ■ ■ 


LCR 


SUBl,., 6, 4. 


68. , , . , , , 80 

■ ■ ■ 1 > 1 i I 1 1 X. _U_ i_ 



CAM 


CHANGE ADDRESSING MODE 




FEATURE on 



FORMAT 



b. 



OP CODE A ADDRESS B ADDRESS VARIANT 





FUNCTION 

Format a; The Change Addressing Mode instruction is used to specify the following conditions, 
as designated by the variant character: 

1. The addressing mode (two-, three-, or four -character ) in which the 
processor is to interpret the address portions of all subsequent 
instructions (see note 1). 

2. The processing mode (standard mode or "trap" mode) in which all 
subsequent instructions are to be processed. (See note 3 for a 
description of the trap mode. ) 

The variant characters and the mode(s) each character represents are listed in 
Table 8-15. 

Format b : The variant character in a previous instruction specifies the addressing mode and 

processing mode in which all subsequent instructions are to be processed. The 
variant characters and the mode(s) each character represents are listed in Table 8-15. 



Table 8-15. Modes Specified by Variant Character in CAM Instruction 



Variant Character 


’ ^ ^ . ■ ' 


(Octal) 


Mode(s) 


20 


Two-character, standard mode 


00 or 40 


Three-character, standard mode 


60 


Four-character, standard mode 


24 


Two-character, trap mode 


04 or 44 


Three-character, trap mode 


64 


Four-character, trap mode 
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WORD MARKS 
Formats a and b: 

Word marks are not affected by this instruction. 



TIMING 

Formats a and b: 

T = Nj^+2 memory cycles. ^ 

ADDRESS REGISTERS AFTER OPERATION 
Formats a and b: 

AAR BAR 

NXT Ap Bp 



NOTES 

1. The CAM instruction is used in conjunction with the ADMODE assembly 
control statement to specify addressing mode. (See page 7-9 for a 
description of the ADMODE statement. ) The ADMODE statement directs 
the Assembly Program to assemble the address portions of all subsequent 
s ource program instructions as two-, three-, or four -character addresses. 
The CAM instruction directs the processor to interpret the address portions 
of all subsequent object program instructions as two-, three-, or four- 
character addresses. Thus, an address assembled in the three -character 
addressing mode (via an ADMODE statement) must be processed during 

a program run as a three -character address for proper execution; the 
processor is placed in the three-character addressing mode during object 
program execution by the CAM instruction. 

2. The ability to change addressing modes within a program makes it possible 
to save both time and memory space and provides greater programming 
flexibility. Extraction and execution time is saved when a smaller ad- 
dressing mode is used, due to the elimination of the extra memory cycles 
necessary for a larger address (in characters). Memory space may be 
conserved by storing frequently used subroutines in the two -character ad- 
dressing mode (see example 1). 

The larger addresses are necessary to address larger continuous portions 
of memory. For instance, a two-character address can address only 
memory locations within a 4, 096 character bank of main memory. A 
three -character address can refer to any location in a 32, 768 -character 
sector. A four-character address can directly address any location in the 
entire memory (from location Ojo location 262, 144^0). 

3. When the processor is in the "trap" mode of instruction execution, any in- 
struction whose op code contains an item mark (or record mark) is both 
extracted and executed as if it were a Change Sequencing Mode instruction 



Subtract one memory cycle if the instruction is being executed in a Type 1201 processor, 
one cycle if the instruction is executed in a Type 2201 processor. 



Add 
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(see page 8- 72), regardless of the op code that is actually present. 
The A address, B address, and variant character (if any) of the 
instruction are delivered to AAR, BAR, and the variant register, 
respectively. The "trapped" op code is not executed; a Change 
Sequencing Mode instruction (CSM) is executed in its place. The 
CSM instruction causes a branch to the location stored in the change 
sequence register (CSR); this location is the beginning of a routine to 
interpret and execute the instruction whose op code was trapped. 

The trap mode is used effectively by the Liberator conversion pro- 
grams (Bridge and Easytran) to replace the seldom used instruc- 
tions of competitive systems when converting the programs of these 
systems to Series 200 language. Such instructions are replaced by 
routines when the trapped op code is executed as a CSM op code. 

This instruction can be coded only in format a. when programming 
for the Type 201 or 201-1 processor. 



EXAMPLE 

Figure 8-5 shows the coding which provides entry to and exit from a subroutine to 
be executed in the two -character addressing mode. Both an ADMODE statement 
and a CAM instruction must be coded (in either order) at the beginning and end of 
the subroutine. However, only the CAM instructions are stored in the main 
memory. (Since CAM instructions have no address portions, the manner in which 
they are stored is not affected by an ADMODE statement. ) 




LOCATION 


OPERATION 

CODE 




8, . 1 . . .14 


15, , , . .20 


, 1 , , 1 








fAAlN . . 


X . , . . 










. . 1 . . . 












. . 1 . , . 


mm 


mmmm 




wwMm 




. . 1 . . . 


WKm 






' / 


— M 


■_! ■ ■ ■ 




■MM 


SUB, 4 












, , 1 . . . 






. . 1 . . . 




MMM 


, , 1 . . . 


mm 


■MM 


, . t . . . 


BS131 


■MM 




mm 




EXIT 


& 





Figure 8-5. Changing Addressing Modes via CAM Instruction 
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NOTE: The branch from the main program to SUB4 in Figure 8-5 could have 
been caused by an item-marked op code (if the processor were in the 
trap mode) instead of by the Branch instruction. In this case, the 
memory location tagged SUB4 would be stored in CSR, so that when 
the item-marked op code was encountered, the contents of SR and CSR 
would be interchanged. The program would automatically branch to 
SUB4 in this case. 



CSM 


CHANGE SEQUENCING MODE 




FEATURES 010 & Oil 



FORMAT 



OP CODE A ADDRESS B ADDRESS VARIANT 




FUNCTION 

Format a: The contents of the sequence register (SR) and the change sequence register (CSR) 

are interchanged, and the program branches to the address which was previously 
stored in CSR. 



Format b: The contents of SR and CSR are interchanged, and the program branches to the ad- 

dress which was previously stored in CSR. The A address is loaded into the A- 
address register (AAR). 



Format c: The contents of SR and CSR are interchanged, and the program branches to the ad- 

dress which was previously stored in CSR. The A and B addresses are loaded into 
AAR and BAR, respectively. 



Format d: The contents of SR and CSR are interchanged, and the program branches to the ad- 

dress which was previously stored in CSR. The A and B addresses and the variant 
character are loaded into AAR, BAR, and the variant register, respectively. 



WORD MARKS 
Formats a, b, c, and d : 

Word marks are not affected by this instruction. 



TIMING 

Formats a, b, c, and d: 

T = Nj^ + 3 memory cycles. ^ 

^Subtract one memory cycle from this formula if the instruction is being executed in a Type 1201 
processor. Add one cycle if the instruction is executed in a Type 2201 processor. 
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ADDRESS REGISTERS AFTER OPERATION 





SR 


CSR 


AAR 


BAR 


Format a: 


JI (contents 
of CSR) 


NXT 


A 

P 




F ormat b: 


JI (contents 
of CSR) 


NXT 


A 


Bp 


Format c: 


JI (contents 
of CSR) 


NXT 


A 


B 


F ormat d: 


JI (contents 
of CSR) 


NXT 


A 


B 



NOTES 

1. The Load Control Registers instruction (see page 8-67) can be used to 
specify the contents of CSR. 

2. When the "trap" mode of instruction execution is specified by the Change 
Addressing Mode instruction (see page 8-69), any subsequent instruction 
whose op code contains an item mark or a record mark is retrieved and 
executed as if it were a Change Sequencing Mode instruction. 

3. This instruction can be coded only in formats a. , b. , and c, when pro- 
gramming for the Type 201 or 201-1 processor. 

EXAMPLE 

Store the absolute address tagged CHANGE in CSR via a Load Control Registers in- 
struction. Later, alter the program sequence by branching to the instruction tagged 
CHANGE. Provide for the ultimate return to normal programming sequence by 
storing the contents of SR in CSR. 



EASYCODER 

CODING FORM 



PROBLEM PROGRAMMER DATE PAGE OF. 



CARD 

NUMBER 


i 


1 


LOCATION 


OPERATION 

CODE 


OPERANDS 




1 .2 1 3 .4 1 5 


6 




8. . 1 . . .14 


15, . , . ,20 




, 1 . , . . ,80 






1 




mm 


CHA.N,G,E,„6,4 




■Wl 




1 


MHHl 


\ ... . 






W1 




- 




-- L ■ . ■ . 


. \ , , , , , , 




HU 




1 


HHH| 


1 , 1 


),,,,, 




HMH 




1 


IHHII 




.. j ................ . 




Wl 




- 










■M 




















HHHi 









HHH 






HHHH 








HMH 








--1 . ■ ■ , 






HHI 






hhhi 








HHMI 






HHHi 








nni 














■HO 






HHHi 








iOm 






L ■ 1 . . . 


MHH 


— ' — ■ — - — i — 1 — I — < — 1 — 1 — 1 — . — ^ ^ — 1 — . — . — . . 1 — .—j . .—1 1 ■ ■ . 1 ■ ■ . ■ 1 ■ . . . 1 1 


1 1 1 1 1 ■ . 1 ■ ■ . . 1 . . ■ ■ 
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EXAA 


EXTENDED MOVE 




FEATURES 010 & 01 1 



FORMAT 



OP CODE A ADDRESS B ADDRESS VARIANT 




FUNCTION 

Format a: The contents of the A field are moved to the B field in the manner specified by the 

variant character (see Table 8-16). The programmer specified how the move 
operation is to be performed by selecting the desired conditions from the table 
and encoding the resulting two octal digits as the variant character of the instruc- 
tion. 



Format b: The contents of the A field are moved to the B field in the manner specified by the 

variant character of a previous instruction (see Table 8-16). 

Format c: The contents of the A field are moved to the field specified by the contents of the 

B-address register (BAR) in the manner specified by the variant character of a 
previous instruction (see Table 8-16). 

Format d: The contents of the field specified by the contents of the A-address register (AAR) 

are moved to the field specified by the contents of BAR in the manner specified by 
the variant character of a previous instruction (see Table 8-16). 



Table 8-16. Extended Move Conditions 



Variant Character 
(Octal) 




XI 


Move A-field data bits to corresponding bit posi- 
tion in B field. 


X2 


Move A-field word-mark bits to corresponding bit 
positions in B field. 


X3 


Move A-field data and word-mark bits to corre- 
sponding bit positions in B field. 


X4 


Move A-field item-mark bits to corresponding 
bit positions in B field. 


X5 


Move A-field data and item-mark bits to corre- 
sponding bit positions in B field. 


X6 


Move A-field word-mark and item-mark bits to 
corresponding bit positions in B field. 
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Table 8-16 (cont). Extended Move Conditions 





- ■} j 


X7 


Move A-field data, word-mark and item-mark 
bits to corresponding bit positions in B field. 


OX 


Move one character from A to B. The A- and B- 
address registers are decremented by one. 


IX 


Move one character from A to B. The A- and B- 
address registers are incremented by one. 


2X 


Move characters from right to left (A and B ad- 
dresses specify rightmost characters in operand 
fields). Terminate the operation when the first 
A-field word mark is sensed. 


3X 


Move characters from left to right (A and B ad- 
dresses specify leftmost characters in operand 
fields). Terminate the operation when the first 
A-field word mark is sensed. 


4X 


Move characters from right to left. Terminate 
the operation when the first A-field item mark 
is sensed. 


5X 


Move characters from left to right. Terminate 
the operation when the first A-field item mark 
is sensed. 


6X 


Move characters from right to left. Terminate 
the operation when the first A-field record mark 
is sensed. 


7X 


Move characters from left to right. Terminate 
the operation when the first A-field record mark 
is sensed. 



PUNCTUATION MARKS 
Formats a, b, c, and d ; 

The A field must have a defining punctuation mark, except when the variant char- 
acter specifies a one-character transfer. 



TIMING 

Formats a, b, c, and d ; 

T = Nj^ + l+ZNg^ memory cycles. ^ 



Add one memory cycle to this formula if the instruction is being executed in a Type 2201 
processor. 
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ADDRESS REGISTERS AFTER OPERATION 



SR AAR BAR 



Format a: 


NXT 


A-Na 


B-Na 


VARIANT = 


( 0 , 


2 , 


4, 


or 


6 )X 




NXT 


A+Na 


B+Na 


VARIANT = 


( 1 , 


3, 


5, 


or 


7)X 


F ormat b: 


NXT 


A-Na 


B-Na 


VARIANT = 


( 0 , 


2 , 


4, 


or 


6 )X 




NXT 


A+Na 


B+Na 


VARIANT = 


( 1 , 


3, 


5, 


or 


7)X 


Format c: 


NXT 


A-Na 


Bp-Na 


VARIANT = 


( 0 , 


2 , 


4, 


or 


6 )X 




NXT 


A+Na 


Bp+Na 


VARIANT = 


( 1 , 


3, 


5, 


or 


7)X 


Format d: 


NXT 


Ap-Na 


Bp-Na 


VARIANT = 


( 0 , 


2 , 


4, 


or 


6 )X 




NXT 


Ap+Na 


Bp+Na 


VARIANT = 


( 1 , 


3, 


5, 


or 


7)X 



NOTES 

1. This instruction can be coded only in formats a. and d. when program- 
ming for the Type 201 or 201-1 processor. 

2. Here is an example of a typical variant bit configuration: V = 110011. 

This configuration, encoded in octal notation as 63, specifies that A-field 
data and word-mark bits are to be moved to the B field from right to left 
until the first record mark is sensed in the A field. 

3. Consider the variant character in its six-bit form, V^V 5 V 4 V 3 V 2 V 2 . If 
Vj = 0, A-operand data bits are not transferred and data bits in the B 
field remain unchanged. 

4. If V 2 = 0, A-operand word-mark bits are not transferred and B-operand 
word-mark bits remain unchanged. 

5. If V 3 = 0, A-operand item-mark bits are not transferred and B-operand 
item-marks remain unchanged. 

6 . The character containing the terminating punctuation is moved in the same 
m.anner as the rest of the field. 



EXAMPLES 

1. Move the data bits of the single character in the location 26 beyond that tagged 
TEMP to the location tagged WORK. 

EASYCODER 

CODING FORM 

PROGRAMMER - DATE PAGE OF 

OPERANDS 

21 , I .... I .... ... I .... I . 6 ^^. 

■ ■ ■ I , I , . i T ■ . 

2 . Move only the data bits in the field tagged RESV to the field tagged WORK. 

Move the data from right to left, and terminate the operation when the 
first item mark in the A field is sensed. 



PROBLEM 



CARD 

NUMBER 


T1 




LOCATION 


' OPERATION 
CODE 


1 2 1 3 4 1 5 


6 i 


7 


8, . , , , .I-* 


15, 20 


cn: 








£m . 
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EASYCODER 



CODING FORM 

PROGRAMMER . DATE PAGE 



CARD 

NUMBER 


7 

£ 


£ 


LOCATION 


OPERATIC N 
CODE 


OPERANDS 




1 .2 |3,4l 5 


6 


Im 


0. . 1 . . .14 


L^J . ,20 


1 .... 1 .... 1 .... .... 1 .... 1 .62 




' I ' 1 






■ 1 ■ ■ ■ 


L^mi 


El.SV,yW,Q,R,K..,4.1. . . . , 






- 


- 


1 . . 1 . , , 


i ... . 




1 1 1 . 1 I i 1 



AAAT 1 MOVE AND TRANSLATE 




FEATURES 010 & Oil 






FORMAT 

OP CODE A ADDRESS 


B ADDRESS VARIANT 1 


VARIANT 2 



FUNCTION 

The MAT instruction translates characters from one six-bit configuration to another 
by means of a stored "translation table. " The instruction can be used to translate 
any number of consecutive characters in the memory. 

The A address specifies the location of the rightmost character to be translated. 

The B address specifies the location into which the translated equivalent of the 
rightmost A-field character will be moved. 

The operation normally terminates when an A-field word mark is sensed. The 
operation is also terminated if a character is transferred from a word-marked lo- 
cation within the translation table. 

The address within the translation table which contains the translated equivalent of 
an A-field character is formed by combining the A-field character with the two 
variant characters. The method of combining these three characters depends on 
the addressing mode being used, as described below. 

The leftmost, or base , address of the translation table is formed by combining 
variants 1, 2, and a zero character as shown below. If the processor is in the two- 
or three-character addressing mode, the leftmost three bits of variant 1 are 
ignored and the corresponding bit positions (i. e. , the sector bits) in the base ad- 
dress (bits 16, 17, and 18) are taken from the contents of the A-address register 
(AAR). If the processor is in the four-character addressing mode (see next page), 
the entire six-bit contents of variant 1 form the leftmost six bits of the base address. 

Two- or Three -Character Addressing Mode 

VARIANT 1 VARIANT 2 





mm 


mm mm 

./V A 


A W ^ A 




X X X X XXIX XX XXXOOOOOOU BASE ADDRESS OF TABLE 
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Four-Character Addressing Mode 



VARIANT 1 VARIANT 2 




BASE ADDRESS OF TABLE 



A character in the A field is translated when it is appended to the variant characters 
(in place of the zero character) to form a complete, 18-bit address. This com- 
plete address contains the translated equivalent of the appended A-field character 
character (see below). 



A-FIELD CHAR. 




COMPLETE, 3 -CHAR. ADDRESS 
CONTENTS 



Note that because of the positions of variant 1 and variant 2 in the total three - 
character address, the base address of the table will always be a multiple of 64, 
This is compatible with translation requirements since each A-field character 
can have any of 64 bit configurations (see note 6). 

It is a simple task to store the desired equivalent values in a translation table. 

For instance, assume that a character set which is to be translated into Honeywell 
code represents the letter A by the bit configuration 110001. Since this bit con- 
figuration represents a binary value of 49, the desired Honeywell equivalent (i.e. , 
010001) should be stored 49 locations beyond the base address of the translation 
table. 



WORD MARKS 

The A field must have a defining word mark. It is this word mark that normally 
stops the operation. The operation will also be terminated if a character is trans- 
ferred from a word-marked location within the translation table. 



TIMING 

T = N^ + 3Na memory cycles. ^ 

ADDRESS REGISTERS AFTER OPERATION 
SR AAR BAR 

NXT A-N^t B-N^t 



Add four memory cycles to this formula if the instruction is being executed in a Type 2201 
processor. 
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CONTROL 



NOTES 

1. This instruction cannot be chained. 

2. The contents of the variant register following a move and translate oper- 
ation are unspecified. Therefore, an instruction requiring a variant 
character must not be chained after an MAT instruction. 

3. Item-mark bits as well as data bits are transferred from the trans- 
lation table to the B field. 

4. Word marks initially stored in the B field remain unchanged. They 
do not affect the execution of this instruction. 

5. The programmer can use a symbolic tag in place of the variant characters 
of this instruction by previously equating the variant characters to the 

tag via a CEQU assembly control statement (see page 7-11). 

6. The base address of the translation table must always be a multiple of 
64. The Easycoder Assembly Program automatically stores the table 
in this manner when directed by a MORG assembly control statement 
(see page 7-7 ) containing an operand of 64. 



EXAMPLE 

Figure 8-6 shows how A -field data is moved to the B field via a translation table. 

Translate the contents of the field tagged EXCODE using the stored translation table 
whose base address is 256io (=400). Store the translated equivalent in the field 
tagged EQUIV. 



A Address : 
B Address : 
Variant 1 ; 
Variant 2: 



EXCODE (absolute value = location 630) 
EQUIV (absolute value = location 900) 
00 = 

base address of table (location 256) 

04 = 



EASYCODER 

CODING FORM 



PROBLEM PROGRAMMER DATE PAGE OF 




Figure 8-6. MAT Operation 
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SECTION 8. INSTRUCTIONS 



MIT I MOVE ITEM AND TRANSLAT^ 



FORMAT 

OP CODE 



A ADDRESS B ADDRESS VARIANT I VARIANT 2 VARIANT 3 




FUNCTION 

The Move Item and Translate instruction is used to translate any information unit 
(up to 12-bit code) to another information unit of up to 1 2 bits (e.g, , to Series 200 
six-bit character code) by the use of a stored translation table. Any number of 
consecutive information units stored in the memory can be translated. 

The A address is the leftmost address of the item to be translated. The B address 
is the leftmost address of the item into which the translated equivalent of the A 
item will be moved. The MIT instruction translates the data contents in the A 
item and moves the translated results, left to right, to the B item. 

The operation normally terminates when an item mark is sensed in the A item. 

The operation will also be terminated if a word-marked character is encountered 
in the translated table. 

An information unit up to six bits in length is stored in one six-bit character lo- 
cation in the memory. Any information unit greater than six bits (7 through 12 
bits) is stored in two successive six-bit character locations. Thus, an information 
unit consisting of up to six bits is considered as a six-bit character, and a unit of 
from 7 to 1 2 bits is considered as a "12-bit character. " 

The sizes of the information units involved in the operation are specified by variant 
3, as shown in Table 8-17. 



Table 8-17. Size of Information Units in MIT Operation 



VARIANT 3 


OPERATION 


00 


Translate each six-bit character in the A 
item. Move the translated equivalent to a 
six-bit character location in the B item. 


01 


Translate each 12-bit character in the A 
item. Move the translated equivalent to 
a six-bit character location in the B item. 


02 


Translate each six-bit character in the A 
item. Move the translated equivalent to 
two character locations (12 bits) in the 
B item. 


03 


Translate each 12-bit character in the A 
item. Move the translated equivalent to 
two character locations (12 bits) in the 
B item. 
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CONTROL 



The desired equivalent of an A-item information unit is taken from the stored 
translation table and moved to the B item. Thus, if the desired equivalent is a six- 
bit character, each table entry occupies one six-bit character location in the table. 
If the desired equivalent is a 12-bit character, each table entry occupies two con- 
secutive six-bit character locations in the table. Consequently, variant 3 implicitly 
specifies the size of each table entry when it explicitly specifies the size of the B- 
item information unit. 

The leftmost, or base, address of the translation table is formed by combining 
variants 1, 2, and a zero character as shown below. If the processor is in the 
two- or three -character addressing mode, the leftmost three bits of variant 1 are 
ignored and the corresponding bit positions (i. e. , the sector bits) in the base ad- 
dress of the table are taken from the contents of the A-address register (AAR). If 
the processor is in the four -character addressing mode, the entire six-bit contents 
of variant 1 form the leftmost six bits of the base address. 

Two- or Three -Character Addressing Mode 



VARIANT 1 VARIANT 2 



XXX 



-o* “V* “V V V 
^ .A. lA. ^ 



BITS 
16-18 
OF AAR 
O 




XXX 


XX X 


X X X X X X 


0 0 0 0 0 0 



= BASE (LEFTMOST) ADDRESS OF TABLE 



Four -Character Addressing Mode 

VARIANT 1 VARIANT 2 



xxxxxxxxxxxx 



/ / 



X X X X X XjX X X X X X|0 0 0 0 0 01= BASE (LEFTMOST) ADDRESS OF TABLE 



The address within the translation table which contains the translated equivalent 
of an A-item character (6- or 12-bit) is formed by superimposing the A-item char- 
acter over the base address of the table. The method of superposition depends on 
the size of each table entry (whether 6 or 1 2 bits), as described below. ^ 

If each table entry is a six-bit character (variant 3 = 00 or 01), the 6- or 12- bit A- 
item character is superimposed over the rightmost bit positions of the base address. 
The illustration below shows a 12-bit A-item character being superimposed over 
the base address, where A = an A-item bit and X = a base address bit. 



Superposition is performed by placing a 1 bit in every position of the table address in which a 1 
existed in either the A-item character or the base address or both. This is the "logical in- 
clusive OR" function. 
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i i 


X X X X X x| 


[X X X X X X 


0 0 0 0 0 0 




X X X X X X 


1 ^!^ 


A A A A A A 



12-BIT A-ITEM CHARACTER 
BASE ADDRESS OF TABLE 

TABLE ADDRESS WHICH CONTAINS THE 6 -BIT 
EQUIVALENT OF A-ITEM CHARACTER 



If each table entry is a 1 2 -bit character (variant 3 = 02 or 03), the 6- or 12-bit A- 
item character is first shifted one bit position to th e left, forming a 7- or 13 -bit 
"character. " The rightmost bit position of the character is set to zero. The 
"character" is then superimposed over the base address to form the table address 
of the translated equivalent of the A-item character. The shift operation is used 
to double the referenced table address, since each table entry is stored in two, 
rather than one, six-bit character locations. The resultant address is the ad- 
dress of the leftmost of the two successive six-bit character locations in the table. 

The illustration below shows how a 6 -bit A-item character is shifted one bit posi- 
tion to the left and then superimposed over the translation table's base address to 
form the table address of its equivalent; A = an A-item bit, and X = a base ad- 
dress bit. 



SHIFT LEFT ONE BIT 
POSITION & APPEND 



A A A A A A 

*777777 



ZERO 


A A A A A A 0 




X X X X X X 


X X X X X X 


0 0 0 0 0 0 




X X X X X X 


X X X X X li 


A A A A A 0 



6 - BIT A-ITEM CHARACTER 

7- BIT "CHARACTER" 

BASE ADDRESS OF TABLE 

TABLE ADDRESS WHICH CONTAINS THE 12-BIT 
EQUIVALENT OF THE A-ITEM CHARACTER 



PUNCTUATION MARKS 

The A item must contain an item mark. It is this punctuation mark that normally 
stops the operation. If the A-item information units are 12-bit characters, the 
terminating item mark may appear in either of the two six-bit character locations. 

The operation will also be terminated if a character (6- or 12-bit) is encountered 
in a word-marked location in the translation table. In this case, neither the word- 
marked character nor any subsequent characters are moved to the B item; instead, 
a sequence change is performed (see note 6). 



TIMING 

T = N^+Ng^+2(N^^)(NB^) memory cycles. ^ 



Add two memory cycles to this formula if the instruction is being executed in a Type 1201 proc- 
essor. Add four memory cycles if it is executed in a Type 2201 processor. 
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CONTROL 



ADDRESS REGISTERS AFTER OPERATION 



SR 



CSR 



AAR 



BAR 



NXT 



CSR. 



A+(NA^)(N^^) B + (NB^)(N^^ 



} 



JI (contents 
of CSR) 



NXT 



A+(NA^)(N^t) B+(NB^)(N^t)} 



A-ITEM ITEM MARK 
STOPS OPERATION 



WORD MARK IN TABLE 
STOPS OPERATION 



NOTES 

1. This instruction cannot be chained. 

2. The last six-bit character referenced in the translation table (whether 
word-marked or not) is left in the variant register following the move 
item and translate operation. 

3. Item-mark bits as well as data bits are transferred from the translation 
table to the B item. 

4. Word marks initially stored in the B item remain unchanged. They do 
not affect the execution of this instruction. 

5. The programmer can use a symbolic tag in place of the variant charac- 
ters of this instruction by previously equating the variant characters to 
the tag via a CEQU assembly control statement (see page 7-11). 

6 . A data control character (e.g., a case-shift character in a teletype code), 
rather than a translated equivalent to be transferred to the B item, can 

be stored in a word-marked location in the table. When this word-marked 
location is sensed, the character in that location is not moved; rather, 
the contents of SR and CSR are interchanged, providing entry to the routine 
whose beginning address was previously stored in CSR. Since the word- 
marked character is stored in the variant register (see note 2 ), that char- 
acter can be stored by a Store Variant and Indicators instruction (see 
page 8 - 90 ) and subsequently tested for identification in the routine. 

7. The base address of the translation table must always be a multiple of 64 
due to the positions of variants 1 and 2 in the total three-character ad- 
dress. This is compatible with the translation requirements of six-bit 
characters. However, if information units greater than six bits in length 
are involved in the translation, a larger table may be required. For 
instance, if a character were to be translated into a seven-bit information 
unit and each seven-bit equivalent were unique, a 1 28 -character table would 
be required. The MORG assembly control statement (see page 7-7) can be 
used to assign memory locations to the table starting with the next available 
memory location whose address is a multiple of 64, 128, 256, etc. , which- 
ever multiple is necessary to allocate the correct number of locations. 

8 . This instruction is a standard feature on all processors except the Types 
201 and 201 - 1 , on which it is not available. 



EXAMPLE 

Figure 8-7 shows how eight-bit code is translated to Series 200 six-bit character 
code by means of a stored translation table. Each eight-bit information unit is 
stored in two consecutive six-bit character locations in the A item tagged EIGHT. 

Translate the data contents of the item tagged EIGHT using the translation table 
whose base address is location 512 jq (IOOO 3 ). Store the translated values (six- 
bit characters) in the item tagged SIX. 
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A Address: EIGHT (absolute value = location 800) 



B Address : 


SIX 


(absolute value = location 650) 


Variant 1 : 


00 - 




Variant 2: 


10 = 


the address of table (location 512) 


Variant 3: 


01 





EASYCODER 

CODING FORM 



PROBLEM _ __ .PROGRAMMER DATE PAGE OF. 





Figure 8-7. MIT Operation 



LOAD INDEX/BARRICADE INDICATOR FEATURE 1114 & 1117 
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CONTROL 



FUNCTION 

Format a : The single character specified by the A address is loaded into the index/barricade 

register (IBR), specifying the number of a 4, 096 -character main memory bank. 
The leftmost location of the specified bank is the leftmost location of the protected 
memory area. (The rightmost location of the protected area is the rightmost lo- 
cation of memory. ) The protected memory area is defined by the single -character 
contents of the A address as shown in Table 8-18, 

Format b : The single character specified by the contents of the A-address register (AAR) is 

loaded into the index/barricade register (IBR), specifying the number of a 4,096- 
character memory bank. The leftmost location of the specified bank is the left- 
most location of the protected memory area. (The rightmost location of the pro- 
tected area is the rightmost location of memory. ) The protected memory area is 
defined by the contents of the previous A address as shown in Table 8-18. 



Table 8-18. Leftmost Boundaries of Protected Memory 



1 Contents of 

1 A Addresii;: :; : V 


Leftmost 
Boundary of 
Protected Memory - 


Contents of 
A Address 


Leftmost 
Boundary of 
Protected Memory 


Octal 


Decimal 


Octal 


Decimal 


0 


0 


0 


40 


32 


131, 072 


1 


1 


4, 096 


41 


33 


135, 168 


2 


2 


8, 192 


42 


34 


139, 264 


3 


3 


12, 288 


43 


35 


143, 360 


4 


4 


16, 384 


44 


36 


147, 456 


5 


5 


20, 480 


45 


37 


151, 552 


6 


6 


24, 576 


46 


38 


155, 648 


7 


7 


28, 672 


47 


39 


159, 744 


10 


8 


32, 768 


50 


40 


163, 840 


11 


9 


36, 864 


51 


41 


167, 936 


12 


10 


40, 960 


52 


42 


172, 032 


13 


1 1 


45, 056 


53 


43 


176, 128 


14 


12 


49, 152 


54 


44 


180, 224 


15 


13 


53, 248 


55 


45 


184, 320 


16 


14 


57, 344 


56 


46 


188, 416 


17 


15 


61, 440 


57 


47 


192, 512 


20 


16 


65, 536 


60 


48 


196, 608 


21 


17 


69, 932 


61 


49 


200, 704 


22 


18 


73, 728 


62 


50 


204, 800 


23 


19 


77, 824 


63 


51 


208, 896 


24 


20 


81, 920 


64 


52 


212, 992 


25 


21 


86, 016 


65 


53 


217, 088 


26 


22 


90, 112 


66 


54 


221, 184 


27 


23 


94, 208 


67 


55 


225, 280 


30 


24 


98, 304 


70 


56 


229, 376 


31 


25 


102, 400 


71 


57 


233, 472 


32 


26 


106, 496 


72 


58 


237, 568 


33 


27 


no, 592 


73 


59 


241, 664 


34 


28 


114, 688 


74 


60 


245, 760 


35 


29 


118, 784 


75 


61 


249, 856 


36 


30 


122, 880 


76 


62 


253, 952 


37 


31 


126, 976 


77 


63 


258, 048 
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WORD MARKS 
Formats a and b: 

Word marks are not affected by this instruction. 



TIMING 

Formats a an d b: 

T = Nj^+3 memory cycles. 



ADDRESS REGISTERS AFTER OPERATION 

SR AAR BAR 

Format a: NXT A -2 B 

P 

Format b: NXT A -2 B 

p p 



NOTES 

1. The 15 additional index registers which are included in the Storage Protect 
Feature are located in the leftmost 60 character locations of the main 
memory bank specified by this instruction. These locations can be used 
as normal storage locations when they are not being used for indexing 
operations. 

2. The LIB op code is a "privileged" op code which has special significance 
when storage protection is in effect with the Type 1201 or 2201 processor 
(see Appendix E). 



EXAMPLE 

Assuming that there are 131, 072 storage locations in the main memory, set up the 
memory in such a way that the "open" memory area consists of locations 0 through 
65, 535 and the protected memory area consists of locations 65, 536 through 
131, 072. The single octal character "20" is contained in the location tagged MP2. 



EASYCODER 

CODING FORM 



PROBLEM 



PROGRAMMER 



DATE 



PAGE OF 



CARD 

NUMBER 


1 


1 


LOCATION 


OPERATION 

CODE 


OPERANDS 




ilIBBEIB 


0! 


a 


8. . 1 . . .14 


I5| . . . .20 


2'. ... 1 .... 1 .... 1 .... 1 1 1 ,,,, 1 .62 


63 , . .80 




1 


1 






Mez 




MN 


1 


1 




DgH 






. 1 1 
1 


_ 


_ 


■ 1 ■ ■ ■ 


1 ■ ■ ■ ■ 


. . . . 1 . ■ L-4. ... i- . t.. . . . . 1 . . . L^_J . 1 J ■ 1 1 ■ . . 1 ■ . ■ . 1 ■ 


-■ 1 . ■ , ■ 1 ■ ■ . ■ 1 ■ , , , 
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CONTROL 



SIB 


STORE INDEX/BARRICADE INDICATOR 




FEATURE 1114 & 1117 



FORMAT 



OP CODE A ADDRESS B ADDRESS 




FUNCTION 

F ormat a ; The single -character contents o£ the index/barricade register (IB) are stored in 
the character location specified by the A address. All high-order bit positions 
in A which are not used to specify the contents of the index/barricade indicator 
are cleared to zeros. 

F ormat b : The single -character contents of the index/barricade register (IB) are stored in 

the character location specified by the contents of the A-address register (AAR). 
All high-order bit positions in A which are not used to specify the contents of the 
index/barricade indicator are cleared to zeros. 



WORD MARKS 
Formats a and b ; 

Word marks are not affected by this instruction. 



TIMING 

Formats a and b ; 

T = Nj^+3 memory cycles. 

ADDRESS REGISTERS AFTER OPERATION 

SR AAR BAR 

Format a : NXT A-2 Bp 

Format b: NXT A-2 B 

P P 

EXAMPLE 

Store the contents of the index/barricade register in the single character location 
tagged PROT. 

EASYCODER 

CODING FORM 



PROBLEM PROGRAMMER DATE PAGE OF 



CARD 

NUMBER 


7 

ij 


g 


LOCATION 


OPERATION 

CODE 


OPERANDS 








1 2 |3 4l 5 


6 


7 


8. . , , , ,14 


15, . . . 20 


1"'. . . , j . , , , 1 . 


. - ■ 1 . i > . 


, . 1 . , , , 1 ,62 


63. , 1 . , 


J ■ 1 . . . 1 > 


1 . .60 








. ■ 1 . . . 






1 1 . . . . I . ■ » . 1 ■ . ■ ■ 1 1__L 


1 _i 1 L.. 


L_J . L_l 1_J ^ _J_ J 1 ,.1.1.. , 
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INTERRUPT CONTROL 



•STORE VARIANT AND INDICATORS 

• RESTORE VARIANT AND INDICATORS 

• MONITOR CALL 

• RESUME NORMAL MODE 
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SYI I STORE VARIANT AND INDICATORS 



FORMAT 



OP CODE A ADDRESS B ADDRESS VARIANT 




FUNCTION 

The SVI instruction is used to store information regarding the current status of the 
processor when an interrupt condition occurs. The instruction stores the designated 
information in up to six consecutive locations following its own variant character. 

Each bit in the six-bit variant character (V^V 5 V^V 3 V 2 Vi ) represents processor 
control registers or indicators whose contents are to be stored in a single character 
location. The programmer specifies the amount of information to be stored by 
selecting the desired entries from Table 8-19 and encoding the resulting bit con- 
figuration as two octal digits. 



Table 8-19* Information Stored by SVI Instruction 









X X X X X 1 


The contents of the variant register. 


X X X X 1 X 


The settings of the arithmetic, comparison, ad- 
dress mode, and item-mark trap mode indicators. 
This information is stored in seven bit positions 
of the character location: the six data bit posi- 
tions and the item-mark bit position. 

The arithmetic and comparison indicators are 
cleared when their contents have been stored. 


XXXI XX 


The contents of the auxiliary indicators regis- 
ter (AIR). These contents are identical to those 
described for V 2 , above. 

The auxiliary arithmetic and comparison indi- 
cators are cleared when their contents have been 
stored. 


X X 1 X X X 


The settings of the indicators associated with the 
scientific unit (see Appendix F). These indi- 
cators are cleared when their contents have 
been stored. 


X 1 X X X X 


The settings of the protect and proceed indi- 
cators and (if the processor is in the external 
interrupt mode) the setting of the internal 
interrupt (II) mode indicator. ^ 
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INTERRUPT CONTROL 



Table 8-19 (cont). Information Stored by SVI Instruction 



VARIANT CHARACTER 



V^V5V4V3V2Vi 



INFORMATION STORED 



X 1 X X X X 
(cont) 



The protect and proceed indicators are cleared 
when their contents are stored. 



1 X X X X X 



The settings of the interrupt source indicators. 
The stored settings of these indicators can be 
tested to determine the status of the processor 
as follows: 



1. Whether the processor is in the external 
interrupt mode, the internal interrupt 
mode, or the standard processing mode. 

2. The source of the interruption if the 
processor is in the external interrupt 
mode; any of three sources can be 
determined — a peripheral control, the 
control panel (or console), or the Monitor 
Call instruction (see page 8-95). 

3. Whether an external interrupt (El) address 
violation^ has occurred (if the processor 
is in the external interrupt mode). 

4. Whether an op code violation^ has oc- 
curred (if the processor is in the internal 
interrupt mode). 

5. Whether an internal interrupt (II) address 
violation^ has occurred (if the processor 
is in the internal interrupt mode). 

The indicators referred to in 3 through 5, above, 
as well as the indicator which identifies the 
control panel (or console) as the interrupt 
source are cleared when their contents are stored. 

These indicators are included in a Type 1201 or 2201 processor equipped with 
the Storage Protect Feature (see Appendix D). 



El address violation, op code violation, and II address violation are 
associated with the Storage Protect Feature (see Appendix D). 



WORD MARKS 

Word marks in the locations in which information is stored neither affect nor are 
affected by this operation. Program operation resumes with the first word-marked 
location following the stored information (the next sequential op code). 



TIMING 

T = N^+l+Ng+Nj memory cycles. ^ 



Add one memory cycle to this formula if the instruction is executed in a Type 1201 processor. 
Add two cycles if the instruction is executed in a Type 2201 processor. 
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ADDRESS REGISTERS AFTER OPERATION 
SR AAR BAR 



NXT Ap Bp 

NOTES 

1. Only the number of characters specified by the variant character are 

stored. They are stored in the order listed in Table 8-19: the contents 
of the variant register {if specified) are stored in the location immedi- 
ately following the SVI instruction, etc. , using only those locations 
actually required to store the requested information. 





StO^j 


SB 'CHARACTER LOCATIOI^ BITS 


I/M BIT 


B BIT 


A BIT j 8 BIT 


4 BIT 


2 BIT 






0 

Item-mark 


Contents of Variant Register 


^2 


Trap- 
mode: 
1 =yes; 
0=no. 


Address mode: 
01 =2 -character; 
00=3 -character; 
1 1 =4-character. 


Overflow 

l=yes; 

0=no. 


: Zero 

Balance : 
l=yes; 

6 =no . 


A< B: 

l=yes; 

0=no. 

>:< 


A = B: 
1 =yes; 
0=no. 


V3 


Contents of AIR (identical to information in above) 

>!« >!« !{< 


V4 


0 


MPO: * 
1 =yes; 
0=no. 


DVC: 

l=yes; 

0=no. 




0 


0 




0 


V5 


0 


Protect 

indi- 

cator: 

1 =on; 

2 = off. 


0 


0 


Proceed 

indi- 

cator; 

1 =on; 
0=off. 

❖ 


0 


In external 
interrupt 
mode only: 

1 =II indi - 
cator on; 
otherwise, 0. 


<! 

0 


Processor is in external interrupt mode 


0 


El Ad- 
dress 
viola- 
lation: 
l=yes; 
0=no. 

5|< 


Monitor 

Call: 

l=yes; 

0=no. 


Control 
panel or 
console 
inter- 
rupt: 

1 =yes; 
0=no. ^ 


Periph- 

eral 

inter- 

rupt: 

l=yes; 

0=no. 


1 


II Mode 
indicator: 
1 =on; 
0=off. 


Processor is not in external interrupt mode 


0 


II Ad- 
dress 
viola- 
tion: 
l=yes; 
0=no. 

❖ 


Op code 
viola- 
tion: 
l=yes; 
0=no. 

* 


0 


0 


0 


II Mode indi- 
cator: 

1 =on; 

0=off. 



= Indicators that are cleared when their contents are stored. 
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2. Item-mark and data bit positions which are not used to store infor- 
mation are cleared to zeros. 

3. The format in which information is stored by the SVI instruction is 
shown in the preceding table. Indicators which are cleared (i. e. , set 
to zero) when their contents are stored are indicated by an asterisk 

4. Bits corresponding to indicators which are not present in the user's 
processor are stored as zeros. For instance, an SVI instruction 
issued in a processor which does not contain the Storage Protect 
Feature will store zeros in those bit positions which correspond to 
indicators used only with the Storage Protect Feature. 

5. The current status of the arithmetic, comparison, address mode, 
and trap mode indicators are not stored in the auxiliary indicators 
register (AIR) when an internal interrupt occurs. The contents of 
AIR should therefore not be stored by an SVI instruction in the internal 
interrupt mode, for the contents of AIR would be meaningless at the 
time of internal interruption. 

6. The SVI op code is a "privileged" op code that has special significance 
when issued in a Type 1201 or 2201 processor equipped with the Storage 
Protect Feature (see Appendix E). 

7. This instruction is a standard feature on all processors but the Types 
201 and 201-1, on which it is not available. 

8. The method of coding interrupt service routines is described in 
Appendix D, "Interrupt Processing." 



EXAMPLE 

Store the following information in the three successive memory locations which 
immediately follow the variant character of the instruction: 

1. The contents of the variant register; 

2. The contents of the auxiliary indicators register (AIR); and 

3. The settings of the interrupt source indicatoi's. 

The op code of the SVI instruction is tagged STORE, so that the locations of the 
stored information are STORE+2, STORE+3, and STORE +4. 



EASYCODER 

CODING FORM 



PROBLEM 



PROGRAMMER 



DATE PAGE OF 



CARD 

NUMBER 


7 

1 


R 


LOCATION 


OPERATION 

CODE 


OPERANDS 




1 .2 |3 4l 5 


6 


7 


8. . 1 . . .14 


I5| . . . 20 


■ 1 ■ ■ ■ ■ 1 ■ ■ ■ . 1 ■ . . . , , . , . 1 . . , , 1 ,62 


66. , 1 . , . . 1 . , . 1 . , 80 


-44- 


1 


1 


5T0,Re 


mmm 






■ 1 ‘ 1 


- 


- 


. ■ 1 ■ ■ ■ 


\ ... . 


-■ — ^ — ■ — ' — 1 — ' — ■ — ' — ■ — 1 — ■ — ■ — . — 1 — 1 — 1 — . — .—1 — . — . — . 1 i_j 1 I 1 . . . . 


-* 1 1 ■ 1 1 1 1 . . ■ ■ 1 -± ■ . . 



RVI 



RESTORE VARIANT AND 
INDICATORS 



FORMAT 

OP CODE A ADDRESS B ADDRESS VARIANT 
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FUNCTION 

Up to five consecutive characters (previously stored via an SVI instruction) are 
loaded into the processor control registers and/or indicators specified by the 
variant character. Characters are retrieved from left to right, beginning with 
the character specified by the A address. 

The low-order five bits of the variant character specify the registers and/or 
indicators whose contents are to be restored. The programmer specifies the 
amount of information to be restored by selecting the desired entries from Table 
8-20 and encoding the resulting bit configurations as two octal digits. 



Table 8-20. Information Restored by RVI Instruction 



VARIANT CHARACTER 


' INFORMATION 


V 6 V 5 V 4 V 3 V 2 VJ 


0 X X X X 1 


The contents of the variant register. 


0 X X X 1 X 


The settings of the arithmetic, comparison, ad- 
dress mode, and item-mark trap mode indi- 
cators. This information is stored in the six 
data bits and the item-mark bit of a character 
location. 


0 X X 1 X X 


The contents of the auxiliary indicators regis- 
ter (AIR), This information is identical to that 
described for above. 


0 X 1 X X X 


The settings of the indicators associated with 
the scientific unit (see Appendix F). 


0 1 X X X X 


The settings of the protect and proceed indi- 
cators and (if the processor is in the external 
interrupt mode) the setting of the internal in- 
terrupt (II) mode indicator. ^ 


^ These indicators are included in a Type 120 1 or 220 1 processor equipped with the Storage Protect 
Feature (see Appendix E). 



WORD MARKS 

Word marks neither affect nor are affected by this instruction. 



TIMING 



T = N-+2+Nj, 



memory cycles, 



^Subtract one memory cycle from this formula if the instruction is executed in a Type 1201 
processor. Add one cycle if the instruction is executed in a Type 2201 processor. 
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ADDRESS REGISTERS AFTER OPERATION 

SR AAR BAR 

NXT A B 

P P 



NOTES 

1. Each entry in the righthand column of Table 8-20 is stored in a single 
character location. Only the number of characters corresponding to 
the selected table entries are restored by the RVI instruction. 

2. The RVI op code is a "privileged" op code that has special significance 
when used with a Type 1201 or 2201 processor equipped with the Storage 
Protect Feature (see Appendix E). 

3. All information stored by an SVI instruction should be restored by the 
RVI instruction. 

4. The format in which information is stored by an SVI instruction is 
shown in the table on page 8-92. Note that the information contained 
in the last character location is not restored by the RVI instruction. 

5. This instruction is a standard feature on all processors but the Types 
201 and 201-1, on which it is not available. 

6. The method of coding interrupt service routines is described in Appendix 
D, "Interrupt Processing. " 



EXAMPLE 



Restore the contents of the variant register and auxiliary indicators register (AIR) 
that were previously stored by the SVI instruction example on page 8- 93. 



EASYCODER 

COOING FORM 



PROBLEM PROGRAMMER DATE PAGE OF 



CARD 

NUMBER 


1 


I 






OPERANDS 




1 2 1 3 4 1 5 


1 


□ 


□HHHBUQ 


miHBi 


2', ... 1 .... 1 .... 1 . I .. 1 , . , . 1 , . , . 1 


® j.. 1 -t .j ... 1 ... . . fi° 


1 1 


1 


1 




[inm 


. . , . 


J J 1. i L JL 1 . 1 














.1.1 










1 1 1 i . . . 1 . 


1 1 












■ 1 ■ 1 












1 1 














vn: 










1 ......... I I , . . . 1 , 



MC I MONITOR CALL 



FORMAT 



OP CODE A ADDRESS B ADDRESS 
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FUNCTION 

The Monitor Call instruction causes the processor to enter the external interrupt 
mode (if the processor is not already in that mode). The following activities are 
automatically performed: 

1. The El interrupt source indicators are set to show that the Monitor Call 
instruction is the source of interruption, and the processor enters the 
external interrupt mode; 

2. The settings of the arithmetic, comparison, address mode, and item- 
mark trap mode indicators are stored in the auxiliary indicators reg- 
ister (AIR); 

3. The arithmetic indicators are cleared; 

4. The contents of the sequence register (SR) and the external interrupt 
register (EIR) are interchanged, and the program branches to the instruc- 
tion whose op code address was previously stored in EIR; 

5. The processor switches to the three -character, non-trap mode. 

WORD MARKS 

Word marks are not affected by this instruction. 



TIMING 

T = N^+2 memory cycles. ^ 

ADDRESS REGISTERS AFTER OPERATION 

SR EIR AAR BAR 

JI (con- NXT Ap Bp 

tents 
of EIR) 



NOTES 

1. This instruction must not be issued in the external interrupt mode. 

2. The interrupt source indicators can be stored via an SVI instruction 
(see page 8-90). Their stored contents can then be interrogated by 
programmed instruction to determine the interrupt source. 

3. This instruction is a standard feature on all processors but the Types 
201 and 201-1, on which it is not available. 



EXAMPLE 

Interrupt the central processor and branch to MONITOR, the location of the monitor 
program. The address tagged MONITOR was previously stored in EIR. 



Subtract one memory cycle to this formula if the instruction is executed in a Type 1201 proc- 
essor. Add one cycle if the instruction is executed in a Type 2201 processor. 
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EASYCODER 

CODING FORM 



PROBLEM 



PROGRAMMER 



DATE 



PAGE OF 



CARD 

NUMBER 


7 


R 

K 


LOCATION 


OPERATION 

CODE 


OPERANDS 




1 .2 |3 ,4l 6 


6 


7 


8. . , . , .14 


I5( . , , .20 


2'. ... 1 .... 1 .... 1 . 1 1 . , 1 


, 1 , , , , 1 , , . . 80 


- , { , i 










A/IQNTQR!,,6,6, , i . 




1 j 














1 1 






. . 1 . . 


, ( 


1 1 1 1 1 III 




, 1 . 1 




r 

L 


. .1 ■ . ■ , 


) 














MC Z* 






1 1 

' 1 ■ 1 








I . . . . 


, . . , . , 


I ._1 . 1 L_1 1 1 I-l . 1 . L 



rnmI RESUME NORMAL MODE 



FORMAT 



OP CODE A ADDRESS B ADDRESS 



b. 



c. 







FUNCTION 

F ormat a ; The RNM instruction causes an exit from the program being executed in the 

interrupt mode (external or internal) to the program which was interrupted. The 
activities performed depend on the type of interrupt mode in which the instruction 
is issued. 

When the RNM instruction is issued in the external interrupt mode: 

1. The El mode indicators are turned off; 

Z. The arithmetic, comparison, address mode, and item-mark trap mode 

indicators are restored to the status specified by the auxiliary indicators 
register (AIR); 

3. The A and B addresses of the RNM instruction are stored in the A- and 
B-address registers (AAR and BAR), respectively; and 

4. The contents of the sequence register (SR) and the external interrupt reg- 
ister (EIR) are interchange^, and the program branches to the instruc- 
tion whose op code address was initially stored in EIR when the external 
interrupt occurred. 

When the RNM instruction is issued in the internal interrupt mode: 

1. The II mode indicator is turned off; 

2. The A and B addresses of the RNM instruction are stored in AAR and 
BAR, respectively; and 

3. The contents of SR and the internal interrupt register (IIR) are inter- 
changed, and the program branches to the instruction whose op code ad- 
dress was initially stored in IIR when the internal interrupt occurred. 
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Format b: This format operates like format a. except that the B address of the RNM instruc- 

tion is not stored in BAR. The previous contents of BAR are not changed. 

Format c: This format operates like format a. except that no instruction addresses are stored. 

The previous contents of AAR and BAR are not affected by this format. 

WORD MARKS 
Formats a, b , and c : 

Word marks are not affected by this instruction. 

TIMING 

Formats a, b, andc: 

T = Nj^ + 3 memory cycles. ^ 



ADDRESS REGISTERS AFTER OPERATION 





SR 


EIR 


HR 


AAR 


BAR 




Format a; 


NXT 


address of op 
code following 
RNM instruction 


n/ a 


A 


B 


RNM ISSUED 
IN EXTERNAL 
INTERRUPT 
MODE 




NXT 


n/a 


address of op 
code following 
RNM instruction 


A 


B 


RNM ISSUED 
IN INTERNAL 
INTERRUPT 














MODE 


F ormat b; 


NXT 


address of op 
code following 
RNM instruction 


n/a 


A 




RNM ISSUED 
IN EXTERNAL 
INTERRUPT 
MODE 




NXT 


n/a 


address of op 
code following 
RNM instruction 


A 




RNM ISSUED 
IN INTERNAL 
INTERRUPT 
MODE 


F ormat c ; 


NXT 


address of op 
code following 
RNM instruction 


n/ a 


A 

P 


B 

P 


RNM ISSUED 
IN EXTERNAL 
INTERRUPT 
MODE 




NXT 


n/a 


address of op 
code following 
RNM instruction 


A 

P 


B 

P 


RNM ISSUED 
IN INTERNAL 
INTERRUPT 



MODE 

NOTES 

1. The address of the instruction which follows the RNM instruction is 

stored in the appropriate interrupt register (EIR or HR) when the RNM 
instruction is executed. This register therefore contains the address 
of the first instruction executed in the interrupt routine when the next 
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interrupt of the same type occurs. This instruction should be an SVI 
instruction, which should be the first instruction executed in any 
interrupt service routine. 

2. The method of coding interrupt service routines is described in 
Appendix D, "Interrupt Processing. " 

3. The RNM op code is a "privileged" op code which has special signif- 
icance when used with a Type 1201 or 220 1 processor equipped with the 
Storage Protect Feature (see Appendix E). 

EXAMPLE 

The simplified coding below shows a convenient method of restoring the starting 
address of the external interrupt routine (EXT2) in EIR when the normal program 
sequence is resumed. 



EASYCODER 

COOING FORM 

PROBLEM PROGRAMMER DATE PAGE OF 






EDITING 



MOVE CHARACTERS AND EDIT 





SECTION 8. INSTRUCTIONS 



MCE 


MOVE CHARACTERS AND EDIT 




FEATURE 013 



FORMAT 



OP CODE A ADDRESS B ADDRESS 




b. 




FUNCTION 

Format a: The MCE instruction is used to insert identifying symbols and punctuation and to 

suppress unwanted zeros in a data field. The A field of an MCE instruction con- 
tains the information to be edited. The B field contains an edit control word which 
provides a framework for the edit operation. When an MCE instruction is executed, 
the data in the A field is moved to the B field where it is punctuated and formatted 
according to the edit control word already stored in thad field. 

NOTE: An LCA instruction can be used to load the control word into the field 
where the edited information will eventually go. For instance, if the edited 
information is to be printed, the control word should be loaded into the print 
image area and the address of this area should be used as the B address of the 
MCE instruction. 

Editing is performed according to the following rules: 

RULE 1. Any character in the Series 200 character set can be used in the edit 
control word. Those characters having special meanings are listed in Table 8-21. 
Any other character, if included in the edit control word, remains in the edited 
result in the position where written. 

RULE 2. A word mark in the high-order position of the B field controls the edit 
operation. 

RULE 3. The number of replaceable characters in the edit control word must be 
at least as large as the number of characters in the A field. 

RULE 4. Data is transferred from the A field character by character, from right 
to left. If a zero suppression symbol is not sensed in the edit control word, the 
edit operation terminates when the B-field word mark is sensed. A zero sup- 
pression symbol causes the edited result field to be scanned from left to right. 
During this scan, high-order zeros and commas are automatically replaced by 
blanks (unless an asterisk appears immediately to the left of the zero suppression 
symbol — see rule 5). Zero suppression is terminated by any of the following: 

a. a decimal digit from 1 through 9, 

b. , a decimal point, or 

c. the location that initially contained the zero suppression symbol. 

RULE 5. An asterisk immediately to the left of the zero suppression symbol in 
the control word causes high-order zeros and commas to be replaced by asterisks 
instead of blanks in a zero suppression operation. High-order blanks are also 
replaced by asterisks. 
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EDIT 



RULE 6. A dollar sign immediately to the left of the zero suppression symbol in 
the control word is replaced with an A-field character and causes the edited result 
to be rescanned following the zero suppression operation. During this scan, the 
dollar sign is "floated" to the left of the high-order significant digit in the edited result. 



Table 8-21. Special Characters in MCE Instruction 



/^‘NTT> r> f*\ T 


FUNCTION 


b (blank) 


Blanks are replaced with A-field characters such 
that the rightmost character in the A field re- 
places the rightmost blank in the edit control word 
and all higher-order A-field characters replace 
successively higher -order blanks. 


0 (zero) 


This symbol specifies zero suppression. Its lo- 
cation in the control word is interpreted as the 
rightmost limit of zero suppression. It is re- 
placed with an A-field character. 


. (decimal point) 


The decimal point remains in the edited field in 
the position where written. 


, (comma) 


Commas remain in the edited field where written 
unless zero suppression is specified (see rule 4). 
Commas in control word positions to the left of 
the high-order character transferred from the 
A field are replaced by blanks. 


Cj^, CR (credit) 

0 (minus) 

NOTE; 0 is printed 
as a minus symbol. 


The credit or minus symbol is undisturbed if the 
sign in the units position of the A field is negative. 
If the sign is positive, the credit (or minus) sym- 
bol is blanked out. A credit (or minus) symbol 
transferred from the A field is not subject to 
sign control. 


378 


An octal 37 is replaced by a blank in the edited 
field. 


'1= (asterisk) 


The asterisk remains in the edited field in the posi- 
tion where written unless it appears immediately 
to the left of the zero suppression symbol (see 
rule 5). 


$ (dollar sign) 


The dollar sign remains in the edited field in the 
position where written unless it appears immedi- 
ately to the left of the zero suppression symbol 
(see rule 6). 



Format b : The data contents of the A field are edited and stored in the field specified by the 

contents of the B -address register (BAR) according to the rules outlined above. 

Format c : The data field specified by the contents of the A-address register (AAR) are 

edited and stored in the field specified by the contents of BAR according to the 
rules outlined above. 
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WORD MARKS 

Formats a, b, and c : 

Both the A field and the B field must have defining word marks. The A-field word 
mark terminates the transfer of data from the A field. The B field word mark 
terminates the edit operation if no zero suppression symbol is sensed in the edit 
control word or if automatic dollar sign insertion is specified in conjunction with 
zero suppression. The B-field word mark is erased after terminating the edit. 

If zero suppression is specified, a word mark is automatically set in the location 

containing the zero suppression symbol. When this word mark is sensed during 

the reverse scan associated with the zero suppression operation, it is erased 

and, if automatic dollar sign insertion is not called for, the edit operation terminates. 

TIMING 

Formats a, b, and c: 

T = N^ + 1 +Ng^+2N-^3+2Z + 2$ memory cycles. ^ 

NOTES 

1. The zone bits in the units position of the A field are cleared to zero when 
moved to the B field. Therefore the value of the character in the units 
position in the A field may change when moved to the B field. For example, 
an F in the units position of the A field will appear as a 6 in the result field. 

2. Floating dollar sign insertion and automatic asterisk insertion can not be 
performed in the same edit operation. 

EXAMPLES 2 



Data Field (A Field) 


@000099 


Control Word (B Field) 


bb, bbO. bb&&;0 


Result of Edit 


. 99 



Example 1 . 



Data Field (A Field) 


@ 5454986 


Control Word (B Field) 


® bb&bb&bbb 


Result of Edit 


254 54 986 



Example 2. 



Add one memory cycle to this formula if the instruction is being executed in a Type 2201 
processor. 

The character {37 g) is shown as an ampersand {&) in these examples. However, the ampersand 

is not the only equivalent of 37 as shown in Table B-6. 

8 
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Data Field (A Field) 


® OO45S 


Control Word (B Field) 


® b,bb0.bb&CR* 


Result of Edit 


$ 4. 50 



Example 3. 



Data Field (A Field) 


® 0897445 


Control Word (B Field) 


0bbb, b$0. bb 


Result of Edit 


$8, 974. 45 



Example 4. 



Data Field (A Field) 


@010450 


Control Word (B Field) 


®b, b^:<0.bb 


Result of Edit 


>:<>:c>;.io4. 50 



Example 5. 
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INPUT/OUTPUT 



• PERIPHERAL DATA TRANSFER 

• PERIPHERAL CONTROL AND BRANCH 
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INPUT/ OUTPUT CONTROL OPERATIONS 

Effective control over data transfers between the central processor and peripheral units 
and over the peripheral units themselves is maintained by the use of two basic instructions: 
Peripheral Data Transfer (PDT), and Peripheral Control and Branch (PCB). The PDT instruc- 
tion is used to initiate data transfer operations and certain other related operations, such as 
backspace magnetic tape and advance the printer form. 

The PCB instruction performs two distinct functions: (1) it initiates strictly mechanical 

operations such as magnetic tape rewinds and card rejections; and (2) it causes a program 
branch to be performed contingent upon the setting of peripheral condition indicators. The 
latter facility allows programmed tests for such peripheral conditions as read or write errors, 
busy peripheral devices or control units, and magnetic tape unit at end of tape. 

Detailed programming and operating information for Series 200 peripheral devices is 
provided in separate manuals and information bulletins. The remainder of this section is a 
summary of the PDT and PCB instructions, based on the assumption that the user is familiar 
with the contents of the applicable publications. 



PDT instructions are described starting on this page — first for all Series 200 devices 
except the Type 286 Multi-Channel Communication Control, and secondly for the Type 286. 
PCB instructions for all Series 200 devices except the Type 286 are described starting on page 
8-117; the description of the Type 286 follows on page 8-131. In all applicable cases, the 
coding summary for a device is followed by a reference to the specific Honeywell manual or 
information bulletin where additional information can be found. 



PDT 



PERIPHERAL DATA TRANSFER 



FORMAT 



For: PUNCHED CARD EQUIPMENT 
PAPER TAPE EQUIPMENT 
PRINTER 

MAGNETIC TAPE EQUIPMENT 
RANDOM ACCESS DRUM 
MASS MEMORY FILE 
CONSOLE 

ON-LINE ADAPTER 

SINGLE- CHANNEL COMMUNICATION CONTROL 
TIME OF DAY CLOCK 

MEMORY TO MEMORY TRANSFER UNIT 
MICR SORTER/ READER 



( I/O CONTROL CHARACTERS) 

QP CODE A ADDRESS Cl C2 C3 




8-108 







INPUT/OUTPUT 



FUNCTION 

The PDT instruction causes data to be transferred between a peripheral device and 
the main memory area whose leftmost location is designated by the A address. Data 
transfer is terminated according to the data medium employed. Input/output control 
characters specify the data path through which the transfer is to be accomplished 
and, when necessary, the method of information transfer according to Table 8-Z2. 

Table 8-22. Description of PDT I/O Control Characters Cl and C2 
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Table 8-22 (cont). Description of PDT I/O Control Characters Cl and C2 



:'idH 


DESCRIPTION 


C2 

i 


PERIPHERAL CONTROL DESIGNATION: Control char- 
acter C2 designates the logical address of the peripheral 
control to be used in the data transfer. This address de- 
pends upon the I/O trunk to which the peripheral control 
is permanently attached. 

Model 200: Eight octal addresses may be employed in a 
Model 200 system containing eight I/O trunks. These ad- 
dresses are as follows: 00, 01, 02, 03, 40, 41, 42, and 
43. In a system equipped with an additional set of eight 
I/O trunks, the following eight addresses may be used: 

04, 05, 06, 07, 44, 45, 46, and 47. 

Model 1200: Sixteen octal addresses may be employed in 
a Model 1200 system equipped with 16 1/0 trunks. These 
addresses are as follows: 00, 01, 02, 03, 04, 05, 06, 

07, 40, 41, 42, 43, 44, 45, 46, and 47. 

Model 2200: Sixteen octal addresses may be employed in 
a Model 2200 system containing 16 1/0 trunks. These ad- 
dresses are as follows: 00, 01, 02, 03, 04, 05, 06, 07, 
40, 41, 42, 43, 44, 45, 46, and 47. In a system equipped 
with an additional set of 16 I/O trunks, the following 16 
addresses may be used: 20, 21, 22, 23, 24, 25, 26, 27, 
60, 61, 62, 63, 64, 65, 66, and 67. 

NOTES: 1, Peripheral controls capable of both reading 
and writing (e. g. , a magnetic tape control) 
must be assigned two addresses — one for 
reading and one for writing. In this case, 
the high-order bit of C2 must be 1 for input 
and 0 for output; the low -order three bits 
must be the same. 

2. For Model 2200 users, the additional set of 
16 I/O trunks must be used only in con- 
junction with RWC4, RWC5, RWC6, and 
RWC4'. 


C3 

through 

Cn 


additional PARAMETERS: The specific use of these 
control characters is dependent upon the type of periph- 
eral device addressed. A summary of coding for these 
characters may be found in Table 8-23. 



PUNCTUATION MARKS 

The execution of this instruction neither affects nor is affected by word marks. 
However, record marks may terminate the data transfer, depending upon the de- 
vice used and the operation performed (see the specific Honeywell manuals and 
information bulletins). 
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TIMING 

Model ZOO Processors : 

T = N^+1 memory cycles + data transfer tim,e. 

Type 1201 Processor : 

T = (N^-Nj 3 + 1) memory cycles + (N^^^+S) input /output cycles + 1 processor cycle 
+ data transfer time. 1 



Type 2201 Processor ; 

T = (N— N^ + 1) memory cycles + alternate memory cycles + data transfer time. 

ADDRESS REGISTERS AFTER OPERATION 
SR AAR BAR 

NXT A B 

P 



NOTES 

1. If either the read/write channel or the peripheral control (specified by 
Cl and C2, respectively) is found "busy" during the extraction of a 
PDT instruction, the instruction is re-extracted : the contents of SR are 
set back to the address of the PDT op code, and the extraction process 
begins again. This process, which allows the processor to respond to 
interrupt signals that may occur while the PDT instruction is awaiting 
the availability of a read/write channel or peripheral control, is not 
performed in the Types 201 and 201-1 processors; PDT extraction in 
these two processors waits until the busy channel or control is available. 

2. The PDT op code is a "privileged" op code when used in a Type 2201 proc- 
essor equipped with the Storage Protect Feature (see Appendix E). 



EXAMPLE 



Read a card into the 80 -character image area tagged CREAD. Use RWC2 and 
assume that the card reader control is assigned to the logical address of octal 41. 



EASYCODER 

CODING FORM 



PROBLEM PROGRAMMER DATE PAGE OF 



CARD 

NUMBER 


7 




LOCATION 


OPERATION 

CODE 


OPERANDS 




IDBEKIBI 


□ 


□ 


s. 1 . . .14 


I5| . . , .20 




63_ 1 1 . 1 . , 1 1 1 , . 1 1 1 , ,®0 


mm 


1 


1 






C(2E.AP,,\,Z,4l. ........ 






1 


1 


1 1 1 . 1 1 


_! . I . 1 







The input /output traffic control of the Type 1201 processor gives one out of every four memory 
cycles unconditionally to the processor for internal operations; this cycle is called the "proc- 
essor cycle. " The three remaining cycles, which can be allocated either to the processor or 
to read/write channels, are called "input/output cycles. " 
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MAGNETIC TAPE 1 /2-INCH 



SECTION 8. INSTRUCTIONS 



Table 8-23. Summary of PDT I/O Control Characters 

T” PDT I/O CONTROL CHARACTER 



INPUT /OUTPUT OPERATION 



Cl C2 C3 C4 

READ/WRITE CONTROL UNIT ADDITIONAL ADDITIONAL 

CHANNEL PARAMETERS PARAMETERS 



ADDITIONAL 

PARAMETERS 




P READ 
PUNCH 



See: Honeywell Series ZQQ Equipment Operators* Manual (File No. 113,0007.0000.0-040) 



XX X' X See Table 

8-24 (page 
8-114) 

X X X^ X See Table 

8-25 (page 

8- 1 14) 



w 

cu 

< 


READ 




w 

A. 

< 

A. 


PUNCH 




See 


: Models 


209/210 Paper Tap 



; Honeywell Series 200 Ec 



READ FORWARD 



READ REVERSE 
(Feature 010 or Oil) 



SPACE FORWARD 





Manual (File No. 113.0007.0000.0-040) 



X^ X 












(D=tape drive, 

0 - 7)3 






none 


2 D 

(D=tape drive, 

0 - 7)4 


none 


none 


none 


2 D 

(D=tape drive, 
0 - 7)3 


none i 


none 


none 


4 D 

(D=tape drive, 
0-7) 


none 


none 


none 


0 D 

(D=tape drive, 


none 


none 


1 none 




^ SKIP WRITE 



Is BACKSPACE 



Honeywell Series 200 Equ 





SEARCH AND READ 


X X 


X* X 


See Table 
8-27 (page 
8-115) 


.0 T T T, 

9-bit track address num- 
bered 0 - 777 (octal) 


S S 

Sector addr 
numbered 0 
47 (octal) 


D 

P£j 

Q 


READ 


X X 


xl X 


See Table 
8-27 (page 
8-115) 


none 


none 


none 


w 

W 

U 

u 

< 


SEARCH AND WRITE 


X X 


X^ X 


See Table 
8-27 (page 
8-115) 


sO T T T X 

9-bit track address num- 
bered 0 - 777 (octal) 


S S 

Sector addr 
numbered 0 
47 (octal) 


o 

Q. 

C 


WRITE 


X X 


X^ X 


See Table 
8-27 (page 
8-115) 


none 


none 


none 




READ ADDRESS REGISTER 


X X 


X* X 


See Table 
8-27 (page 
8-115) 


none 


none 


none 


Se 


e: Model 270 Random Access 


Drum and Control (File No. 113.0005. 


300. 0-009) 









I 

■ 

I 
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INPUT/OUTPUT 



Table 8-23 (cont). Summary of PDT I/O Control Characters 



INPUT/OUTPUT OPERATION 


PDT I/O CONTROL CHARACTER | 


Cl 

4EAD/WRITE 

CPIANNEL 


C2 

CONTROL UNIT 


C3 

ADDITIONAL 

PARAMETERS 


C4 

ADDITIONAL 

PARAMETERS 


C5 

ADDITIONAL 

PARAMETERS 


06 

ADDITIONAL 

PARAMETERS 




LOAD ADDRESS REGISTER 


X X 


X^ X 


4 X 

(X=nnused) 


none 


none 


none 


STORE ADDRESS REGISTER 


X X 


X^ X 


4 X 

(X=unused) 


none 


none 


none 


MASS MEMORY FILE 


SEARCH AND READ 


X X 


X* X 


2 D 

(D=device address) 


none 


none 


none 


SEARCH AND WRITE 


X X 


X^ X 


2 D 

(D=device address) 


none 


none 


none 


SEARCH AND READ NEXT 


X X 


X* X 


3 D 

{D=device address) 


none 


none 


none 


SEARCH AND WRITE NEXT 


X X 


X^ X 


3 D 

(D=device address) 


none 


none 


none 


READ INITIAL 


X X 


X^ X 


0 D 

(D=device address) 


none 


none 


none 


READ 


X X 


X* X 


1 D 

(D=device address) 


none 


none 


none 


FORMAT WRITE INITIAL 


X X 


X 


0 D 

(D=dcvice address) 


none 


none 


none 


FORMAT WRITE 


X X 


2 

X^ X 


1 D 

(D=device address) 


none 


none 


none 


1 See: Mass Memory File Controland Transports (File No, 112.0005,1400.0-060) 


CONSOLE 


READ (NO CARRIAGE 
RETURN) 


X X 


x‘ X 


0 0 


none 


none 


none 


READ (CARRIAGE RETURN) 


X X 


X^ X 


0 1 


none 


none 


none 


WRITE (NO CARRIAGE 
RETURN) 


X X 


X^ X 


0 0 


none 


none 


none 


WRITE (CARRIAGE RETURN) 


X X 


x2 X 


0 1 


none 


none 


none 


1 See: Honeywell Series 200 Equipment Operators' Manual (File No. 113. 0007.0000.0-040) 


ON-LINE ADAPTER 


TRANSFER ID character to 
Model 200, Model 1200, or 
Model 2200 memory. 


X X 


X X 


4 X 

(X=unused) 


none 


none 


none 


ACCEPT the H-800/1800 in- 
struction defined in the ID 
register. 6 


X X 


X X 


0 0 


none 


none 


none 


ACCEPT the H-800/1800 in- 
struction defined in the ID 
register, and cause the H-800/ 
1800 to branch to U+4 or U+5.^ 


X X 


X X 


0 4 


none 


none 


none 


DO NOT ACCEPT the H-800/ 
1800 instruction defined in the 
ID register; rather, cause 
the H-800/1800 program to 
branch to lT+6 or U+7 (read 
or write error). ^ 


X X 


X X 


1 u 

(U = any value 
from 0-7, octal) 


none 


none 


none 


SET the device busy indicator.^ 


X X 


X X 


3 X 

{X=unuscd) 


none 


none 


none 


1 See: Model 212 On-Line Adapter (File No. 112.0007. 1601,00.00) 


TYPE 281 

sccc 


RECEIVE 


X X 


X* X 


none 


none 


none 


none 


TRANSMIT 


X X 


X^ X 


none 


none 


none 


none 


— 

TIME OF 
DAY CLOCK 


TRANSFER TIME TO 
MEMORY 


X X 


X* X 


none 


none 


none 


none 


MEMORY TO MEM- 
ORY TRANSFER UNIT 


TRANSFER DATA 


X X 


X X 


none 


none 


none 


none 


MICR 

SORTER/READER 


TRANSFER DATA 


X X 


X* X 


none 


none 


none 


none 


NOTES: 1. The high-order bit must be 1, 

2. The high-order bit must be 0. 

3. Odd parity is assumed. If even parity is required, the first octal character should be 7, 

4. Odd parity is assumed. If even parity is required, the first octal character should be 3. 

5. Odd parity and short gap are assumed. 

6. This operation issues initiating and concluding device-ready responses. 
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SECTION 8. INSTRUCTIONS 



Table 8-Z4. C3 Coding for Type 209 Paper Tape Reader 



BIT 

VALUE 




ILJ 


5 


4 


3 


Z 


1 


1 


Not used 


One character 
per frame 


Sense end 
of record 


Check odd 
parity 


F orward 


Increment 

RWC 


0 


Not used 


Two charac- 
ters per frame 


Do not 
sense end 
of record 


Check even 
parity 


Reverse 


Decrement 

RWC 



Table 8-25. C3 Coding for Type 210 Paper Tape Punch 



BIT 

VALUE 






mm4\ 


■ —w 


litiM 


3 


2 


1 


1 


Not used 


One character 
per frame 


Not used 


Compute odd 
parity 


00 = Do not punch parity 

01 = Parity bit in chan- 

nel six 

10 = Parity bit in chan- 
nel seven 

11= Parity bit in chan- 
nel eight 


0 


Not used 


Two charac- 
ters per frame 


Not used 


Compute 
even parity 



Table 8-26. C3 Coding for Types 206 and 222 Printers 





Type 222 


||||« 


, INTERPRETATION 


C3 


INTERPRETATION 


OOnnnn 


Print, then space the number of lines 


OOnnnn 


Print, then space the number of lines 




specified by nnnn (1 - 15). 




specified by nnnn (0 - 15). 


0 1 nnnn 


Print, then space to the head of the 


0 1 nnnn 


Print, then space to channel one of 




form if the end of the form is sensed; 




the format tape (HOF) if channel two 




otherwise, space the number of lines 




of the format tape (EOF) is sensed; 




specified by nnnn (1 - 15). 




otherwise, space the number of lines 
specified by nnnn (0 - 15). 


1 1 nnnn 


Do not print; space the number of 


1 1 nnnn 


Do not print; space the number of 




lines specified by nnnn (1 - 15). 




lines specified by nnnn (0 - 15). 


100011 


Print, then space to the head of the 


1 OOxxx 


Print, then space to channel xxx. 




form. 


101 XXX 


Do not print; space to channel xxx. 


101111 


Do not print; space to the head of 


000 


Channel 3 




the form. 


001 


Channel 4 






010 


Channel 5 






01 1 


Channel 1 (Head of form) 






100 


Channel 6 






101 


Channel 7 






1 10 


Channel 8 






1 1 1 


Chainnel 1 (Head of form) 
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INPUT/OUTPUT 



Table 8 - 27 . C3 Coding for Type 270 Random Access Drum 





^ 






1 








1 


Override 


Increment drum 
address register 


This is a Read Ad- 
dress Register in- 
struction 


Drum file designation 
0-7 (octal) 


0 


Do not 
override 


Do not increment 
drum address 
register 


This is not a Read 
Address Register 
instruction 



PDT I PERIPHERAL DATA TRANSFER 



For: MULTI-CHANNEL COMMUNICATION 
CONTROL 



FORMAT 



( I/O CONTROL CHARACTERS) 

OP CODE A ADDRESS Cl C2 




FUNCTION 

This PDT instruction causes data to be transferred between the Multi-Channel Com- 
munication Control and the main memory area designated by the A address. Input/ 
output control character Cl designates the read/write channel through which the 
data will be transferred, while C2 designates the peripheral control address. Both 
Cl and C2 are described in Table 8-22 (see page 8-109). 

PUNCTUATION MARKS 

The execution of this instruction neither affects nor is affected by word marks or 
record marks . 



TIMING 

Model 200 Processors: 

T = N^ + 1 memory cycles + data transfer time. 

Type 1201 Processor : 

T = (Nj^-N(, + 1) memory cycles + (N^jj+3) input/output cycles + 1 processor cycle + 
data transfer time. ^ 



The input /output traffic control of the Type 1201 processor gives one out of every four memory 
cycles unconditionally to the processor for internal operations; this cycle is called the "proc- 
essor cycle. " The three remaining cycles, which can be allocated either to the processor or 
to read/write channels, are called "input /output cycles. " 
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SECTION 8. INSTRUCTIONS 



Type 2201 Pr ocessor; 

T = (Nj^-N^ + l) memory cycles + N^ alternate memory cycles + data transfer time. 

ADDRESS REGISTERS AFTER OPERATION 
SR AAR BAR 

NXT A B 

P 



NOTES 

1. If either the read/write channel or the peripheral control (specified by Cl 
and C2, respectively) is found "busy" during the extraction of a PDT in- 
struction, the instruction is re-extracted; the contents of the sequence 
register are set back to the address of the PDT op code, and the extrac- 
tion process begins again. This process, which allows the processor to 
respond to interrupt signals that may occur while the PDT instruction 

is awaiting the availability of a read/ write channel or peripheral control, 
is not performed in the Types 201 and 201-1 processors; PDT extraction 
in these two processors waits until the busy channel or control is available. 

2. The PDT op code is a "privileged" op code when used in a Type 2201 
processor equipped with the Storage Protect Feature (see Appendix E). 



Table 8-28. Summary of PDT I/O Control Characters for Type 286 Multi-Channel 

Communication Control 





A ADDRESS 








C3 ,, 


FIRST DATA TRANSMISSION PDT 


LOC 

(specifies "line 0" 
in 286) 


X X 


mu 


none 


RECEIVE DATA PDT 


LOC + 2 

(specifies line ad- 
dress in 286) 


X X 


X^ X 


none 


TRANSMIT DATA PDT 


LOC+2 

(specifies line ad- 
dress in 286) 


X X 


X^ X 


none 


LINE CONTROL PDT 


LOC 

(specifies address 
of line to be con- 
trolled) 

NOTE: The six- 
line control trans- 
mission PDT in- 
structions are listed 
in Table 8-29, below. 


X X 


X^ X 


none 


NOTES: I. The high-order bit must be 1. 

2. The high-order bit must be 0. 
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INPUT/OUTPUT 



Table 8-29. Type 286 Line Control Instructions 



CO0E^ 

(OCTAL) 






10 


Transmit last 
character 


Inform the 286 that the last character has 
been sent from the central processor, and 
place the control unit in the receive mode 
for that line (after transmitting last char- 
acter). 


60 


Receive clear 


Reset the bits of the logic character in the 
286 memory. (This instruction should be 
given when power is first turned on. ) 


30 


Inhibit 285 (ser- 
vice request) 


Turn off the interrupt capability of a line 
that is requesting service (either input or 
output ). 


50 


Transmit idle 
character 


Repeat the previously provided character 
indefinitely, without interrupts. 


40 


Transmit 


Stop the line from repeating character 
and cause an interrupt. 


74 


Move Longitudinal 
Redundancy Check 
(LRC) Character 


Move the LRC character from the LRC 
register to the data buffer register. 


NOTE; The control code is stored in location LOC + 1. (The high-order four bits of this 
location contain the code; the low-order two bits must be 0. ) 



PCB I peripheral control and branch 



For: PUNCHED CARD EQUIPMENT 
PAPER TAPE EQUIPMENT 
PRINTER 

MAGNETIC TAPE EQUIPMENT 
RANDOM ACCESS DRUM 
MASS MEMORY FILE 
CONSOLE 

ON-LINE ADAPTER 
SINGLE -CHANNEL COMMUNICATION 
CONTROL 
INTERVAL TIMER 
TIME OF DAY CLOCK 

m;emory to memory transfer unit 

MICR SORTER/ READER 



FORMAT 

OP CODE A ADDRESS 



(I/O CONTROL CHARACTERS) 
Cl C2 C3 Cn 





FUNCTION 

The Peripheral Control and Branch instruction can initiate two types of operations: 
(1) test operations, and (2) control operations. 
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SECTION 8. INSTRUCTIONS 



1. Test operations test the status of the peripheral control to which the 
PCB instruction is issued (e.g., test for a "busy" status, test to 
determine if an error is present, etc. ) 

2. Control operations set the peripheral control to perform a specific 
control function(e. g. , reject error cards when addressed to card 
controls, rewind the tape when addressed to a magnetic tape control, etc. ) 

The A address of a PCB instruction specifies a main memory location to which the 
machine branches if the test conditions specified by C3 through Cn are present. If 
the PCB instruction is initiating a control operation, the A address specifies the 
main memory location to which a branch is made if the peripheral device is unavail- 
able . 

Cl designates the read/write channel. The function of this character is the same 
as its function for a PDT instruction; see Table 8-22 (page 8-109). 

C2 designates the peripheral control. The function of this character is the same as 
its function for a PDT instruction; see Table 8- 22 (page 8-109). 

Control characters C3 through Cn designate the control and test operations. The 
specific use of these control characters is dependent upon the type of peripheral 
device addressed. A summary of coding for these characters may be found in 
Table 8-30 (see page 8-119). 

PUNCTUATION MARKS 

The execution of this instruction neither affects nor is affected by word marks or 
record marks . 



TIMING 

Model 200 Processors ; 

T = N^+1 memory cycles if no branch condition exists. 
T = N^+2 memory cycles if a branch occurs. 



Type 1201 Pr ocessor : 

T = (N— N(, + l) memory cycles + N^, input /output cycles. ^ 

Type 2201 Pr ocessor : 

T = (Nj^-N^ + 1) memory cycles + N^, alternate memory cycles. 
ADDRESS REGISTERS AFTER OPERATION 



SR 


AAR 


BAR 




NXT 


A 


B 


NO BRANCH 






P 




JI (A) 


A 


NXT 


BRANCH 



The input /output traffic control of the Type 1201 processor gives one out of every four memory 
cycles unconditionally to the processor for internal operations; this cycle is called the "proc- 
essor cycle. " The three remaining memory cycles, which can be given either to the processor 
or to read/write channels, are called "input /output cycles. 
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INPUT/OUTPUT 



NOTES 

1. Control character Cl tests the status of a read/write channel. If an 
RWC status test is not desired. Cl must contain zeros. 

2. The PCB op code is a "privileged" op code when used in a Type 2201 
processor equipped with the Storage Protect Feature (see Appendix E). 



EXAMPLE 

In the following example, assume that the logical address of the card reader control 
is octal 41 . 

Set the card reader control to read Hollerith, code (C3 = 27) and to reject automati- 
cally all cards with hole-count errors (C4 = 21). If the device is inoperable, branch 
to the location tagged STOP. (Note that since an RWC is not to be tested. Cl must 
contain zeros. ) 



EASYCODER 

CODING FORM 



PROBLEM PROGRAMMER DATE PAGE OF. 



CARD 

NUMBER 


l\ 


LOCATION 


OPERATION 

CODE 


OPERANDS 


1 2 1 3 4 1 5 


6 


8 , ,1 . , ,14 


> 5 | . , . .20 




. , 1 , . . .... 1 .62 






. . ■ 1 ■ . ■ 


P,06 


STOP. ,O0,4-i,.27.2,l 



Table 8-30. Summary of PCB I/O Control Characters 










C2 


03 through Cn 


TYPE 214-1 CARD PUNCH 


Branch to A address if device busy 


X X 


X^ X 


1 0 


Branch to A address if punch-check error 


X X 




4 1 


Branch to A address 
if device unavailable. 
If available, set con- 
trol unit to: 


Punch Hollerith 

code^ 


X X 




2 7 


Punch special code 


X X 


X^ X 


2 6 


Punch direct tran- 
scription code (fea- 
ture 064) 


X X 


x2 X 


2 5 


Generate busy sig- 
nal if punch-check 
error 


X X 


X2 X 


2 3 


Reject cards with 
punch-check error 


X X 


X^ X 


2 1 


Turn the control allow function OFF 


X X 


X^ X 


7 0 


Turn the control allow function ON 


X X 


X^ X 


7 1 


Turn the control interrupt function OFF 


X X 


X^ X 


7 4 


Branch to A address if the control interrupt 
function is ON 


X X 


X2 X 


7 5 
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TYPE 214-2 CARD READER/CARD PUNCH 



SECTION 8. INSTRUCTIONS 



Table 8-30 (cont). Summary of PCB I/O Control Characters 



TEST AND CONTROL OPERATIONS 



PCB I/O CONTROL CHARACTERS 



Cl 



C2 



C3 through Cn 



Branch to A address if device busy 



X X 



X^ X 



1 0 



Branch to A address if punch-check error 



X X 



X^ X 



Branch to A address if illegal punch 



X X 



X3 X 



4 1 



4 2 



Branch to A address 
if device unavailable. 
If available, set con- 
trol unit to: 



Terminate punch-feed 
read operations, op- 
erate in Hollerith mode, 
and accept all error 
cards'^ 



X X 



X3 X 



Punch special code 



X X 



X^ X 



Punch direct tran - 
scription code (fea- 
ture 064) 



X X 



X^ X 



Generate busy signal 
if illegal punch 



X X 



X^ X 



Generate busy signal 
if punch-check error 



X X 



X^ X 



Reject cards with 
illegal punches 



X X 



X^ X 



Reject cards with 
punch-check error 



X X 



X^ X 



Operate in punch-feed 
read mode 



X X 



X^ X 



2 7 



2 6 



2 5 



2 4 



2 3 



2 1 



2 0 



Turn the control allow function OFF 



X X 



X 



7 0 



Turn the control allow function ON 



X X 



X^ X 



7 1 



Turn the control interrupt function OFF 



X X 



3 

X X 



7 4 



Branch to A address if the control interrupt 
function is ON 



X X 



X^ X 



7 5 
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INPUT/OUTPUT 



Table 8-30 (cont). Summary of PCB I/O Control Characters 



[i 




Cl 


C2 




TYPE 223 CARD READER 


Branch to A address if device busy 


X X 


X^ X 


1 0 


Branch to A address if cycle check error 


X X 


X^ X 


4 1 


Branch to A address if illegal punch 


X X 


X^ X 


4 2 


Branch to A address 
if device unavailable. 
If available, set con- 
trol unit to: 


Read Hollerith code 
and accept all error 
cards^ 


X X 


X^ X 


2 7 


Read special code 


X X 


X^ X 


2 6 


Read direct tran- 
scription code (fea- 
ture 044) 


X 


X^ X 


2 5 


Reject cards with 
cycle check error 


X X 


X^ X 


2 1 


Reject cards with 
illegal punches 


X X 


xl X 


2 2 


Generate busy sig- 
nal if cycle check 
error 


X X 


xl X 


2 3 


Generate busy sig- 
nal if illegal punch 


X X 


X^ X 


2 4 


Turn the control allow function OFF 


X X 


X^ X 


7 0 


Turn the control allow function ON 


X X 


X^ X 


7 1 


Turn the control interrupt function OFF 


X X 


X^ X 


7 4 


Branch to A address if the control interrupt 
function is ON 


X X 


X^ X 


7 5 


See: Honeywell Series 200 Equipment Operators' Manual (File No, 113,0007,0000. 0-040) 
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Table 8-30 (cont). Summary of PCB I/O Control Characters 



TEST AMB CONTROl:. OFEEATXONS'’ 


PCB I/O CONTROL CHARACTERS 


Cl 


C2 


C3 through Cn 


TYPE 224 CARD READER/ CARD PUNCH 


Branch to A address if device busy 


X X 


X^ X 


1 0 


Branch to A address if echo-check or read 
registration errors 


X X 


X^ X 


4 1 


Branch to A address if illegal punch 


X X 


X^ X 


4 2 


Branch to A address 
if device unavailable. 
If available, set con- 
trol unit to: 


Terminate punch-feed 
read operations, op- 
erate in Hollerith 
mode, and accept all 
error cards'^ 


X X 


X^ X 


2 7 


Convert to special code 


X X 


X^ X 


2 6 


Operate in direct 
transcription mode 
(feature 064) 


X X 


x3 X 


2 5 


Generate busy signal 
if illegal punch 


X X 


x3 X 


2 4 


Generate busy signal 
if echo-check or read 
registration errors 


X X 


x3 X 


2 3 


Reject cards with il- 
legal punches 
(feature 065) 


X X 


X3 X 


2 2 


Reject cards with echo- 
checker read registra- 
tion errors (feature 
065) 


X X 


wm 


2 1 


Operate in punch-feed 
read mode 


X X 


wm 


2 0 


Turn the control allow function OFF 


X X 


X^ X 


7 0 


Turn the control allow function ON 


X X 


X^ X 


7 1 


Turn the control interrupt function OFF 


X X 


X3 X 


7 4 


Branch to A address if the control interrupt 
function is ON 


X X 


X^ X 


7 5 


See: Honeywell Series 200 Equipment Operators’ Manual (File No. 1 1 3. 0007. 0000. 0-040) 


TYPE 227 CARD 
READER 


Branch to A address if device busy 


X X 




1 0 


Branch to A address if hole -count error 


X X 


xl X 


4 1 


Branch to A address if illegal punch 


X X 


X^ X 


4 2 


Branch to A address 
if device unavailable. 
If available, set con- 
trol unit to: 


Terminate punch-feed 
read operations (fea- 
ture 06 2), if applicable, 
operate in Hollerith 
mode, and accept all 
error cards'^ 


X X 


X^ X 


2 7 













































































INPUT/OUTPUT 
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Table 8-30 (cont). Summary of PCB I/O Control Characters 



PCB I/O CONTROL CHARACTER 



Branch to A address | Read special code 
if device unavailable. 



If available, set con- 
trol unit to: 



Read direct tran- 
scription code (fea- 
ture 040) 



Reject cards with 
hole-count errors 



Reject cards with 
illegal punches 



Generate busy sig- 
nal if hole -count 



Generate busy sig- 
nal if illegal punch 



Place previously 
read card in mid- 
dle stacker (fea- 
ture 017) 



Place previously 
read card in the 
read eject stacker 
(feature 017-1) 



Turn the control allow fimction OFF 



Turn the control allow function ON 



Turn the control interrupt function OFF 



Branch to A address if the control interrupt 
function is ON 



See: Honeywell Series ZOO Equipment Operators' Manual (File No. 113,0007.0000,0-040) 



1 0 




C3 throug 






2 


6 


2 


5 


2 


1 


2 


2 


2 


3 


2 


4 


3 


1 


3 


2 


7 


0 


7 


1 




Branch to A address if device busy 


X X 


X^ X 


Branch to A address if hole-count error (fea- 
ture 06l ) 


X X 


X^ X 


Brcinch to A address 
if device unavailable. 
If available, set con- 
trol unit to: 


Terminate punch-feed 
read operations (fea- 
ture 062), if applicable, 
and punch Hollerith 
code'4 


X X 


X^ X 




Pvinch special code 


X X 


X^ X 




Punch direct tran- 
scription code (fea- 
ture 060) 


X X 


X^ X 
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SECTION 8. INSTRUCTIONS 



Table 8-30 (cont). Summary of PCB I/O Control Characters 



4 TEST AND CONTROL OPERATIONS 


PCB I/O CONTROL CHARACTERS 


Cl 


C2 


C3 through Cn 


TYPE 227 CARD PUNCH (cont) 


Branch to A address 
if device unavailable. 
If available, set con- 
trol unit to: 


Reject cards with 
illegal punches (fea- 
ture 052) 


X X 


X2 X 


2 2 


Reject cards with 
hole -count errors 
(feature 061) 


X X 


X2 X 


2 1 


Punch-feed read 
operations (fea- 
ture 062) 


X X 


X2 X 


2 0 


Place previously 
punched card in 
middle stacker 
(feature 017) 


X X 


X^ X 


3 1 


Place previously 
punched card in the 
punch eject stacker 
(feature 017-1) 


X X 


X^ X 


3 2 


Turn the control allow function OFF 


X X 


X^ X 


7 0 


Turn the control allow function ON 


X X 


X^ X 


7 1 


Turn the control interrupt function OFF 


X X 


x2 X 


7 4 


Branch to A address if the control interrupt 
function is ON 


X X 


X^ X 


7 5 



See: Honeywell Series 200 Equipment Operators' Manual (File No. 113.0007.0000.0-040) 



TYPE 209 PAPER TAPE READER 


Branch to A address if device busy 


X X 


X^ X 


1 X 

(X=unused) 


Branch to A address if parity error 


X X 


X^ X 


4 X 

(X=unused) 


Branch to A address 
if device unavailable. 
If available, set con- 
trol unit to: 


Rewind the tape (re- 
verse direction) 


X X 


X^ X 


3 0 


Runout the tape (for- 
ward direction) 


X X 


X^ X 


3 2 


Turn the control allow function OFF 


X X 


X^ X 


7 0 


Turn the control allow function ON 


X X 


X^ X 


7 1 


Turn the control interrupt function OFF 


X X 


X^ X 


7 4 


Branch to A address if the control interrupt 
function is ON 


X X 


X^ X 


7 5 


|see: Models 209/210 Paper Tape Equipment (DSI-322) 
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INPUT /OUTPUT 






Table 8-30 (cont). Summary of PCB I/O Control Characters 



B I/O CONTROL CHARACTER 



TEST AND CONTROL OPERATION 



Branch to A address if device busy 



W [jj Turn the control allow function OFF 

: 

p Turn the control allow function ON 
o 



1 




X X 


X^ X 


X X 


X^ X 


X X 


X^ X 


X X 


X^ X 


X X 


X^ X 



1 



W Turn the control interrupt function OFF 

ft < 

Branch to A address if the control interrupt 

function is ON 



See: Models 209/210 Paper Tape Equipment (DSI-322) 




o 


ft 


(U 


w 


w 

ft 


ft 




ft 




ft 



Branch to A address if device busy 


X X 


X2 X 


1 0 


Branch to A address if print error 


X X 


X^ X 


4 0 



See: Honeywell Series 200 Equipment Operators' Manual (File No, 113.0007.0000.0-040) 



X2 X 



X2 X 





Branch to A address if device busy 


X X 


Branch to A address if print error 


X X 


Branch to A address if paper is moving 


X X 


Branch to A address if busy or paper is moving 


X X 


Branch to A address if end of form 


X X 


Branch to A address if channel eight 


X X 


Turn the control allow function OFF 


X X 


Turn the control allow function ON 


X X 


Turn the control interrupt function OFF 


X X 


Branch to A address if the control interrupt 
function is ON 


X X 




X^ X 



X2 X 



X2 X 



X2 X 



X^ X 



1 


0 


4 


0 


2 


0 


3 


0 


0 


1 


0 


2 


7 


0 


7 


1 




See: Honeywell Series 200 Equipment Operators' Manual (File No. 113.0007.0000.0-040) 
Note: PCB instructions with C3 characters 01, 02, 20, and 30 are not applicable to the 
222-5 printer. 
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SECTION 8. INSTRUCTIONS 



Table 8-30 (cont). Summary of PCB I/O Control Characters 



' , ' - ' - ' - 

TEST AND CONTROL OPERATIONS 




mm 1 


C2 




MAGNETIC TAPE UNITS 1/2 INCH 


Rewind 


X X 


x2 X 


2 D 

(D=tape drive, 
0 - 7) 


Rewind and release 


X X 


X^ X 


2 D 

(D=tape drive, 
0 - 7) 


Branch to A address if read busy 


X X 


X^ X 


0 D 

(D=tape drive, 
0-7) 


Branch to A address if write busy 


X X 


x2 X 


0 D 

(D=tape drive, 
0-7) 


Branch to A address if read/write error 


X X 


X^ X 


4 D 

(D=tape drive, 
0-7) 


Branch to A address if beginning of tape 


X X 


X^ X 


6 D 

(D=tape drive, 
0 - 7) 


Branch to A address if end of tape 


X X 


X^ X 


6 D 

(D=tape drive, 
0 - 7) 


Turn the control allow function OFF 


X X 


X^ X 


7 0 


Turn the control allow function ON 


X X 


X^ X 


7 1 


Turn the control interrupt function OFF 


X X 


X^ X 


7 4 


Branch to A address if the control interrupt 
function is ON 


X X 


X^ X 


7 5 


See; Honeywell Series 200 Equipment Operators' Manual (File No. 113.0007.0000.0-040) 


MAGNETIC TAPE UNITS 
3/4 INCH 


Rewind 


X X 


X^ X 


2 D 

(D=tape drive, 
0 - 7) 


Release 


X X 


X^ X 


2 D 

(D=tape drive, 
0 - 7) 


Branch to A address if read busy 


X X 


X^ X 


0 D 

(D=tape drive, 
0-7) 


Branch to A address if write busy 


X X 


X^ X 


0 D 

(D=tape d rive, 
0 - 7) 


Branch to A address if read/write error 


X X 


X^ X 


4 D 

(D=tape drive, 
0-7) 
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INPUT/OUTPUT 



Table 8-30 (cont). Summary of PCB I/O Control Characters 



TEST AND CONTROL OPERATIONS 


I PCB I/O CONTROL CHARACTERS 




ca 




MAGNETIC TAPE UNITS 
3/4 INCH (cont) 


Branch to A address if beginning of tape 


X X 


X^ X 


6 D 

(D=tape drive, 
0-7) 


Branch to A address if end of tape 


X X 


X^ X 


6 D 

(D=tape drive, 
0-7) 


Branch to A address if "long check" error 
is detected 


X X 


X^ X 


5 X 

(X=unused) 


Turn the control allow function OFF 


X X 


X^ X 


7 0 


Turn the control allow function ON 


X X 


X^ X 


7 1 


Turn the control interrupt function OFF 


X X 


X^ X 


7 4 


Branch to A address if the control interrupt 
function is ON 


X X 


X^ X 


7 5 


See: Series 203A/204A Three-Quarter Inch Magnetic Tape Systems (DSI-342) 


TYPE 270 RANDOM 
ACCESS DRUM 


Branch to A address if device busy^ 


xl X 


X X 


0 X or 1 X 
(X=unused) 


Branch to A address if error indicator is on 


X^ X 


X X 


4 X 

(X=unused) 


Turn the control allow function OFF 


X^ X 


X X 


7 0 


Turn the control allow function ON 


X^ X 


X X 


7 1 


Turn the control interrupt function OFF 


X^ X 


X X 


7 4 


Branch to A address if the control interrupt 
fvmction is ON 


X^ X 


X X 


7 5 


|see: Model 270 Random Access Drum and Control (File No. 113.0007.0000. 0-040) 


H 

l-H 

Ph 

O 


Branch to A address if control busy 


X^ X 




1 X 

(X=unused) 


Branch to A address if device busy 


X^ X 


X^ X 


0 D 

(D=device 

address) 


w 

in 

in 

< 

% 


Branch to A address if general exception 


X^ X 


x2 X 


5 X 

(X=unused) 


Branch to A address if TLL flag 


X^ X 


X^ X 


5 X 

(X=unused) 
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MASS MEMORY FILE (cont) 



SECTION 8. INSTRUCTIONS 



Table 8-30 (cont). Summary of PCB I/O Control Characters 





PCB I/O CONTROL CHARACTERS 






Cl 


C2 


C3 through Cn 


Branch to A address 
if specified transport 
is busy. If not busy, 
set control unit to: 


Seek out the strip 
(specified by C5 
and C6) in the 
cartridge (speci- 
fied by C4) 


X 


— -'H 

X^ X 


03: 2 D 

(D=device 
, address) 

C4: 0 0 for 

Types 251 
and 252; 

0 0 to 
0 4 for 
Type 253 

C5 and C6: 0000 
to 0777 




Return the tape strip 
currently on the 
read/write drum (if 
any) to the cartridge. 


X^ X 


X^ X 


3 D 

(D=device 

address) 




Return the tape strip 
currently on the 
read/write drum to 
the cartridge. Sim- 
ultaneously, if 
another strip is on 
the waiting platform 
(or is in the process 
of being placed on 
the platform), that 
strip is also returned 
to the cartridge. 


X^ X 


X^ X 


3 D 

(D=device 

address) 


Turn the control allow function OFF 


xl X 


X^ X 


7 0 


Turn the control allow function ON 


X^ X 


X^ X 


7 1 


Turn the transport allow function OFF 


X^ X 


X^ X 


7 2 


Turn the transport allow function ON 


X^ X 


X^ X 


7 3 


7 

Turn the control interrupt function OFF' 


X^ X 


X^ X 


7 4 


Branch to A address if the control interrupt 
function is ON 


X^ X 


X^ X 


7 5 


Turn the transport inte 


rrupt function OFF 


X^ X 


X^ X 


7 6 


Branch to A address if the transport interrupt 
fimction is ON 


X^ X 


X^ X 


7 7 



See; Mass Memory File Control and Transports (File 


No. 112.0005.1400.0-060) 


r-H 

o W 

(\j 1-1 
CS] 0 

w S 
&0 


Branch to A address if device busy 


X X 


X2 X 


1 0 


See: Honeywell Series 200 Equipment Operators' Manual (File No. 113. 0007.0000. 0-040) 
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INPUT /OUTPUT 




Table 8-30 (cont). Summary of PCB I/O Control Characters 



ST AND CONTROL OPERATIONS 



1 PCB I/O CONTROL C 




C2 


X X 


X^ X 


X X 


X^ X 


X X 


X^ X 





Branch to A address if device busy 
^ Reset the interrupt function 

o W — 

1 -^ Branch to A address if the interrupt ftxnction 

W S is ON 

Oh g 
!>h O 
H O 



Honeywell Series 200 Equipment Operators' Manual (File No. 113.0007.0000.0-040) 



Branch to A address if device busy 



Turn the allow function OFF 



Turn the allow function ON^ 



Turn the data termination interrupt 
function OFF 



Branch to A address if data termination 
interrupt function is ON 



Turn the manual interrupt function OFF^ 



Branch to A address if manual interrupt 
function is ON*^ 



Branch to A address if device busy 




Branch to A address if data transfer is in 
progress 



Branch to A address if error or incom- 
plete indicator is set 



Branch to A address if parity error is 
stored 



Branch to A address if incomplete error 
is stored 



Place control character C4 in the ID reg- 
ister if data transfer is not in progress 



Branch to A address unconditionally, and 
clear the ID register 





X 



xl X 




X^ X 
X^ X 



X^ X 



X^ X 



X^ X 



0 X or 1 X 
(X=unused) 



7 X 

(X=unused) 





5 X 

(X=unused) 



6 X 

(X=unused) 

C3: 2 X 
(X=unused) 



C4: octal char- 
acter to be 
placed in 
ID register 

3 X 

(X=unused) 







































































SECTION 8. INSTRUCTIONS 



Table 8-30 (cont). Summary of PCB I/O Control Characters 



TEST AND CONTROL OPERATIONS 


PCB I/O CONTROL CHARACTERS 


Cl 




C3 through Cu 




Branch to A address if device busy 


X X 


x3 


X 


1 0 




Branch to A address if parity error 


X X 


x^ 


X 


4 0 




Branch to A address if error other than 
parity error 


X X 


x^ 


X 


5 0 


u 

u 

u 

in 


Branch to A address if the 281 is in 
transmit mode and requesting data for 
transmission onto line 


X X 


x^ 


X 


6 0 


00 

oo 

w 

Ph 


Branch to A address if the 281 is in re- 
ceive mode and requesting that central 
processor take received data 


X X 


x^ 


X 


6 1 


H 


Turn the allow fiuiction OFF 


X X 


x^ 


X 


7 0 




Turn the allow function ON 


X X 


x^ 


X 


7 1 




Turn the interrupt function OFF 


X X 




X 


7 4 




Branch to A address if allow and interrupt 
functions are ON 


X X 


x^ 


X 


7 5 


W 

5! 


Branch to A address if device busy 
(Feature 071) 


0 0 


x6 


X 


1 0 


Turn the allow function OFF 


0 0 


x^ 


X 


7 0 


HH 

H 


Turn the allow function ON 


0 0 


x6 


X 


7 1 


c 

> 

w 


Turn the allow function ON (Feature 071) 


0 0 




X 


7 3 

(C4 - C6 specify 
time interval) 


Eh 

t— 1 


Turn the interrupt function OFF 


0 0 


x6 


X 


7 4 




Branch to A address if interrupt function 
is ON 


0 0 


x^ 


X 


7 5 




Turn the interrupt function OFF 
(Feature 071) 


0 0 


x^ 


X 


7 6 




Branch to A address if an interrupt is 
designated by Feature 071 (Feature 071) 


0 0 


x^ 


X 


7 7 


1 

1 U 

1 O 

5 -1 

1 ^ O 












TYPE 213- 
TIME OF DAY 


Branch to A address if device busy 


X X 


xi 


X 


1 0 
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TYPE 212-1 MEMORY- TO- MEMORY 



INPUT /OUTPUT 



I 

i 



Table 8-30 (cont). Summary of PCB I/O Control Characters 



TEST AND CONTROL OPERATIC 






Branch to A address if device busy 



Branch to A address if device busy, and 
reserve 



Branch to A address if reserve action by 
this central processor was not successful 



Branch to A address if 212-1 is not set for 
data transfer (initiator) 



Branch to A address if 212-1 is set for 
data transfer (responder) 



Turn the allow function OFF 



Turn the allow function ON 



Turn the interrupt function OFF 



Branch to A address if allow and interrupt 
functions are ON 



Branch to A address if control busy 



Select stacker designated; 
Branch to A address if: 



the Sorter-Reader is not 
ready; or 

the 10 -millisecond stacker 
selection period has elapsed; [Stacker 4 
or 



Stacker 0 
Stacker 1 
Stacker 2 
Stacker 3 



Stacker 5 
Stacker 6 
Stacker 7 
Stacker 8 



PCB I/O CONTROL CHARACTERS 



C3 through Cn 



X^ X 


x^ 


X 


0 X or 
1 0 


X^ X 


X! 


X 


C3: 


2 0 








C4: 


0 0 


X! 

X! 


X^ 


X 


C3: 


2 0 








C4: 


0 0 








C5: 


6 1 


X^ X 


x6 


X 


6 1 



the leading edge of the 
document to be sorted has 
not passed the reading 
station; or 

the leading edge has passed 9 

the reading station and a 

PDT instruction has not yet Stacker X 
been issued; or 



oeenissuea; or Stacker Y 

5. the Sorter-Reader is per- Reject 
forming an automatic reject stacker 
on the document in question 



Start feed. Branch to A address if feed can- 
not be started due to: 

1. the Sorter-Reader not being 
ready; or 

2. Proper restart procedures 
not followed 



X 



X^ X 



xi X 



Xl X 



xi X 



X X 



X X 



X X 



X X 



X X 



X X 



X X 



X X 



X X 



X X 



X X 



X X 



X X 



X X 




X^ X 



X^ X 



X^ X 
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TYPE 233-2 MICR SORTER-READER (cont) 



SECTION 8. INSTRUCTIONS 



Table 8-30 (cont). Summary of PCB I/O Control Characters 



TEST AND CONTROL OPERATIONS 







Cl 


' C2 


C3 through Cn 


Branch to A address if Sorter-Reader is not 
ready 


X 


X 


x2 


X 


3 


5 


Branch to A address if: 

1. the Sorter-Reader is not ready; or 

2. a pocket light control PCB is already 
in process 


X 


X 


x^ 


X 


3 


6 


Branch 


Amount field error 


X 


X 


x^ 


X 


4 


0 


to A 

address 

if: 


Process control field error 


X 


X 


x^ 


X 


4 


1 


Account field error 


X 


X 


x^ 


X 


4 


2 




Transit field error 


X 


X 


x2 


X 


4 


3 




Auxiliary on-us field error 


X 


X 


x2 


X 


4 


4 




Device error 


X 


X 


x2 


X 


5 


0 




Passed document condition 


X 


X 


x^ 


X 


5 


1 


Operate 


in normal mode 


X 


X 


x^ 


X 


6 


0 


Operate 


in short-document mode 


X 


X 


x2 


X 


6 


1 


Branch to A address if on-us field is 
complete 


X 


X 




X 


6 


2 


Branch to A address if last document was 
a control document 


X 


X 


x^ 


X 


6 


3 


Branch to A address if end-of-file 


X 


X 


x^ 


X 


6 


4 


Turn allow function OFF 


X 


X 


x2 


X 


7 


0 


Turn allow function ON 


X 


X 


AA 


X 


7 


1 


Turn interrupt function OFF 


X 


X 


■AF 


X 


7 


4 


Branch to A address if interrupt function 
is ON 


X 


X 


X^ 


X 


7 


5 



PCB I/O CONTROL CHARACTERS 



NOTES: 1. The high-order bit must be 1. 



2. The high-order bit must be 0. 

3. The high-order bit is set to 1 for input operations and to 0 for output 
operations. 

4. This control character should precede all other control characters that 
set the control to perform a certain action. It is the programmer's 
responsibility to set the control to the desired mode of operation at the 
beginning of the run. 



5. As the drum control does not permit reading from one drum file while 
writing on another, it is considered busy if either a read or a write 
operation is in progress. (The value of the high-order bit in C2 is thus 
immaterial in this case. ) 
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INPUT /OUTPUT 



6. The high-order bit is ignored. 

7. The interrupt functions of both the control and transport are automatically 
turned on when a "not busy" status is reached by the control or transport, 
respectively. 

8. For program interruption in the 201-0 central processor, the processor 
must contain the Program Interrupt Feature (012). 

9. The manual interrupt function is applicable only in those cases where the 
Type 220-3 is employed with the 201-0 or 201-1 central processor; C3 
control characters 76 and 77 perform no operations with other central 
processors. In those cases where the 201-0 or 201-1 is not equipped 
with the Program Interrupt Feature (012), the manual interrupt function 
can still be tested or turned off. Thus although the interrupt button cannot 
effect a manual interrupt, the corresponding function can be tested to set 
up a programmed interrupt. 



PCB 



PERIPHERAL CONTROL AND BRANCH 



For: 



MULTI-CHANNEL COMMUNICATION 
CONTROL 



FORMAT 



(I/O CONTROL CHARACTERS) 

OPCODE A ADDRESS Cl C2 C3 Cn 




FUNCTION 

The Peripheral Control and Branch instruction can initiate two types of operations: 

(1) test operations, and (2) control operations. 

1. Test operations test the status of the peripheral control to which the PCB 
instruction is issued. 

2. Control operations set the peripheral control to perform a specific 
control function. 

The A address of a PCB instruction specifies a main memory location to which the 
machine branches if the test conditions specified by C3 through Cn are present. If 
the PCB instruction is initiating a control operation, the A address is immaterial 
(although it must still be present in the instruction). 

Cl designates the read/write channel. The function of this character is the same as 
its function for a PDT instruction; see Table 8-22 (page 8-109). 

C2 designates the peripheral control. The function of this character is the same as 
its function for a PDT instruction; see Table 8-22 (page 8-109). 

Control characters C3 through Cn designate the control and test operations. A 
summary of coding for these characters may be found in Table 8-31 (see page 8-132). 



PUNCTUATION MARKS 

The execution of this instruction neither affects nor is affected by word marks or 
record marks. 
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SECTION 8. INSTRUCTIONS 



TIMING 

Model 200 Processors: 

T = Nj^+1 memory cycles if no branch condition exists. 
T = N^+2 memory cycles if a branch occurs. 



Type 1201 Pr ocessor: 

T = (Nj^-Nj, + 1) memory cycles + N^. input/output cycles. ^ 

Type 2201 Processor : 

T = (N^-Nj,+1) memory cycles + N^ alternate memory cycles. 

ADDRESS REGISTERS AFTER OPERATION 
SR AAR BAR 



NXT 


A 




NO BRANCH 


JI (A) 


A 


NXT 


BRANCH 



NOTES 

1. Control character Cl tests the status of a read/write channel. If an RWC 
status test is not desired, Cl must contain zeros. 

2. The PCB op code is a "privileged" op code when used in a Type 2201 proc- 
essor equipped with the Storage Protect Feature (see Appendix E). 



Table 8-31. Summary of PCB I/O Control Characters for Type 286 
Multi-Channel Communication Control 







I 


C2 




Branch to A address if device busy. If 
not busy, set the 286 to stop scanning 
and continue the program in sequence^ 


X X 


X2 X 


1 0 


Turn the allow function OFF 


X X 


X2 X 


7 0 


Turn the allow function ON 


X X 


X^ X 


7 1 


Branch to A address if the interrupt was 
due to the 286 requesting service 


X X 


X2 X 




NOTES: 1. The busy test has no significance for the Type 286. 
2. The high-order bit has no significance. 



The three out of every four memory cycles which can be allocated to either the processor or to 
read/write channels are referred to as "input/output cycles. " 
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OCTAL NOTATION 



APPENDIX 

A 



Octal notation is a convenient shorthand method of writing pure binary numbers. In Series 
200 programming it is used to represent such binary values as main memory addresses, variant 
characters, I/O control characters, and constants. 

If a binary value is divided into groups of three bits, proceeding from right to left, each 
group may be replaced by its octal equivalent as indicated in Table A-1. 

Table A-1. Binary-Octal Equivalents 





OCTAL 

EQUIVALENT 


000 


0 


001 


1 


010 


2 


on 


3 


100 


4 


101 


5 


no 


6 


111 


7 



Example 1 . 

The binary value 

011111000101001110 
when divided into three -bit groups 

on 111 000 101 001 no 

has an octal equivalent of 

3 7 0 5 1 6 



Example 2. 

The binary value 

1010100111010 

when divided into three -bit groups 
1 010 100 111 010 
has an octal equivalent of 
1 2 4 7 2 
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APPENDIX A. OCTAL NOTATION 



Table A-2. Decimal-Octal Conversion Table 



DECIMAL INCREMENT 



LOW-ORDER 
OCTAL DIGIT 


000 

001 

002 

003 

004 

005 

006 
007 


008 

009 

010 

011 

012 

013 

014 

015 


016 

017 

018 

019 

020 
021 
022 
023 


024 

025 

026 

027 

028 

029 

030 

031 


032 

033 

034 

035 

036 

037 

038 

039 


040 

041 

042 

043 

044 

045 

046 

047 


048 

049 

050 

051 

052 

053 

054 

055 


056 

057 

058 

059 

060 
061 
062 
063 


064 

065 

066 

067 

068 

069 

070 

071 


072 
07 3 

074 

075 

076 

077 

078 

079 


080 

081 

082 

083 

084 

085 

086 
087 


oaa 

089 

090 

091 

092 

093 

094 

095 


096 

097 

098 

099 

100 
101 
102 
103 


104 

105 

106 

107 

108 
109 
no 
111 


1 12 

113 

114 

115 

116 

117 

118 
119 


120 

121 

122 

123 

124 

125 

126 
127 


128 

129 

130 
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15, 000 


15, 200 


3554 


3555 


3556 


3557 


3560 


3561 


3562 


3563 


3564 


3565 


3566 


3567 


3570 


3571 


3572 


3573 


3574 


3575 


3576 


3577 


3600 


3601 


3602 


3603 


3604 


15, 200 


15, 400 


3605 


3606 


3607 


3610 


3611 


3612 


3613 


3614 


3615 


3616 


3617 


3620 


3621 


3622 


3623 


3624 


3625 


3626 


3627 


3630 


3631 


3632 


3633 


3634 


3635 


15, 400 


15, 600 


36 36 


3637 


3640 


3641 


3642 


3643 


3644 


3645 


3646 


3647 


3650 


3651 


3652 


3653 


3654 


3655 


3656 


3657 


3660 


3661 


3662 


3663 


3664 


3665 


3666 


15, 600 


15, 800 


3667 


3670 


3671 


3672 


3673 


3674 


3675 


3676 


3677 


3700 


3701 


3702 


3703 


3704 


3705 


3706 


3707 


3710 


371 1 


3712 


3713 


3714 


3715 


3716 


3717 


15, 800 


16, 000 


3720 


3721 


3722 


3723 


3724 


3725 


3726 


3727 


3730 


3731 


3732 


3733 


3734 


3735 


3736 


3737 


3740 


3741 


3742 


3743 


3744 


3745 


3746 


3747 


3750 


16, 000 


16, 200 


3751 


3752 


3753 


3754 


3755 


37 56 


3757 


3760 


3761 


3762 


3763 


3764 


3765 


3766 


3767 


3770 


3771 


3772 


3773 


3774 


3775 


3776 


3777 


4000 


4001 


16, 200 


16, 400 


4002 


4003 


4004 


4005 


4006 


4007 


4010 


4011 


4012 


4013 


4014 


4015 


4016 


4017 


4020 


4021 


4022 


4023 


4024 


4025 


4026 


4027 


4030 


4031 


4032 


16, 400 



HIGH-ORDER OCTAL DIGITS 
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APPENDIX A. OCTAL NOTATION 



OCTAL-DECIMAL CONVERSION PROCEDURE 

Consider the decimal number to be converted as a base and an increment. Locate the base 
(the next lower number which is evenly divisible by 200) in the margin of the lower chart and the 
increment in the body of the upper chart. The intersection of the row and column thus defined 
contains the high-order digits of the octal equivalent. The low-order digit appears in the mar- 
gins of the upper chart opposite the increment. For example, to convert 7958 to octal, the base 
is 7800 and the increment is 158. Locate 158 in the upper chart and read down this column to 
the 7800 row below. The high-order octal result is 1742. Then read out to the margin of the 
upper chart to obtain the low-order digit of 6. Append (do not add) this digit to 1742 for an octal 
equivalent of 17,426. 

To convert an octal number to decimal, locate the high-order digits in the body of the 
lower chart and the low-order digit in the margin of the upper chart. Then perform the converse 
of the above operation. 
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Table B-1. Control Register Designations 



OCTAL ADDRESS 
(Control Panel or 
Console Addressing) 


VARIANT CHARACTER 
(LCR & SCR Instructions) 




REGISTER 


200 


1200 & 2200 




Mnemonic 


F unction 


01 


01 


01 


CLCl 


Read/ Write Channel 1 
Current Location Counter 


02 


02 


02 


CLC2 


Read/ Write Channel 2 — 
Current Location Counter 


03 


03 


03 


CLC3 


Read/ Write Channel 3 — 
Current Location Counter 


05 


0 5 


05 


CLCl' 


Read/ Write Channel 1' — 
Current Location Counter 


1 1 


11 


11 


SLCl 


Read/ Write Channel 1 — 
Starting Location Counter 


12 


12 


12 


SLC2 


Read/ Write Channel 2 — - 
Starting Location Counter 


13 


13 


13 


SLC3 


Read/ Write Channel 3 — 
Starting Location Counter 


15 


15 


15 


SLCl' 


Read/ Write Channel 1' — 
Starting Location Counter 




21 ^ 


21 


CLC4 


Read/ Write Channel 4 — 
Current Location Counter 




22,1 


22 


CLC5 


Read/ Write Channel 5 — 
Current Location Counter 




23I 


23 


CLC6 


Read/ Write Channel 6 — 
Current Location Counter 




25I 


25 


CLC4' 


Read/ Write Channel 4' — 
Current Location Counter 




31 1 


31 


SLC4 


Read/ Write Channel 4 — 
Starting Location Counter 




32I 


32 


SLC5 


Read/ Write Channel 5 — 
Starting Location Counter 




33I 


33 


SLC6 


Read/ Write Channel 6 — 
Starting Location Counter 




35I 


35 


SLC4' 


Read/ Write Channel 4' 
Starting Location Counter 
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Table B- 1 (cont). Control Register Designations 



OCTAL ADDRESS 
(Control Panel or 
Console Addressing) 


VARIANT CHARACTER 
(LCR & SCR Instructions) 


REGISTER 


200 


1200 & 1200 




Mnemonic 


Function 


04 


64 


64 


CSR 


Change Sequence Register 


06 


66 


66 


EIR 


External Interrupt Register 


14 


74 


67 


AAR 


A-Address Register 


10 


70 


70 


BAR 


B-Address Register 


n/ a 


76 


76 


HR 


Internal Interrupt Register 


17 


77 


77 


SR 


Sequence Register 


n/ a 


41-43 


n/ a 


ACO 


Floating-Point Accumulator 0 


n/ a 


45-47 


n/ a 


ACl 


Floating-Point Accumulator 1 


n/ a 


51-53 


n/ a 


AC2 


Floating-Point Accumulator 2 


n/ a 


55-57 


n/ a 


AC3 


Floating-Point Accumulator 3 


2200 only. 



Table B-2. Extended Move (EXM) Conditions 



CONDITIONS 


^6 


VARIANT 

Vc V. V 
5 4 


BITS 

^2 


■^1 




Type of Move 
















1. A-field data bits — ►B 


X 


X 


X 


X 


X 


1 




2. A-field word-mark bits — »-B 


X 


X 


X 


X 


1 


X 




3. A-field item- mark bits — ►B 


X 


X 


X 


1 


X 


X 




Direction of Move 
















1. right to left 


X 


X 


0 


X 


X 


X 




2. left to right 


X 


X 


1 


X 


X 


X 




Termination of Move 
















1. automatic after single-character move 


0 


0 


X 


X 


X 


X 




2. A-field word mark 


0 


1 


X 


X 


X 


X 




3. A-field item mark 


1 


0 


X 


X 


X 


X 




4. A-field record mark 


1 


1 


X 


X 


X 


X 
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Table B-3. Branch on Condition Test (BCT) SENSE Switch Conditions 



VARIANT CHARACTER 
(Octal) 


BRANCH CONDITION 


00 


Unconditional 


01 


SENSE Switch 1 On 


02 


SENSE Switch 2 On 


03 


SENSE Switches 1 and 2 On 


04 


SENSE Switch 3 On 


05 


SENSE Switches 1 and 3 On 


06 


SENSE Switches 2 and 3 On 


07 


SENSE Switches 1, 2, and 3 On 


10 


SENSE Switch 4 On 


11 


SENSE Switches 1 and 4 On 


12 


SENSE Switches 2 and 4 On 


13 


SENSE Switches 1, 2, and 4 On 


14 


SENSE Switches 3 and 4 On 


15 


SENSE Switches 1, 3, and 4 On 


16 


SENSE Switches 2, 3, and 4 On 


17 


SENSE Switches 1, 2, 3, and 4 On 


20 


Unconditional 


21 


SENSE Switch 5 On 


22 


SENSE Switch 6 On 


23 


SENSE Switches 5 and 6 On 


24 


SENSE Switch 7 On 


25 


SENSE Switches 5 and 7 On 


26 


SENSE Switches 6 and 7 On 


27 


SENSE Switches 5, 6, and 7 On 


30 


SENSE Switch 8 On 


31 


SENSE Switches 5 and 8 On 


32 


SENSE Switches 6 and 8 On 


33 


SENSE Switches 5, 6, and 8 On 


34 


SENSE Switches 7 and 8 On 


35 


SENSE Switches 5, 7, and 8 On 


36 


SENSE Switches 6, 7, and 8 On 


37 


SENSE Switches 5, 6, 7, and 8 On 


NOTE; When testing for a multiple SENSE switch condition, a branch 
occurs only if all of the specified conditions are met. 
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Table B-4. Branch on Condition Test (BCT) Indicator Conditions 



VARIANT CHARACTER 
(Octal) 


BRANCH CONDITION 


41 


B<A (Low Compare) 


42 


B=A (Equal Compare) 


43 


B£A (Low or Equal Compare) 


44 


B>A (High Compare) 


45 


B^A (Unequal Compare) 


46 


B ^A (High or Equal Compare) 


47 


Unconditional 


50 


Overfl ow 


51 


Overflow or B < A 


52 


Overflow or B=A 


53 


Overflow or B < A 


54 


Overflow or B>A 


55 


Overflow or B^A 


56 


Overflow or B >A 


57 


Unc onditional 


60 


Zero Balance 


61 


Zero Balance or B<A 


62 


Zero Balance or B=A 


63 


Zero Balance or B <A 


64 


Zero Balance or B >A 


6 5 


Zero Balance or B^A 


66 


Zero Balance or B>A 


67 


Unc onditional 


70 


Overflow or Zero Balance 


71 


Overflow or Zero Balance or B<A 


72 


Overflow or Zero Balance or B=A 


73 


Overflow or Zero Balance or B<A 


74 


Overflow or Zero Balance or B>A 


75 


Overflow or Zero Balance or B^A 


76 


Overflow or Zero Balance or B >A 


77 


Unconditional | 


NOTE: When testing for a multiple indicator condition, a branch 


occurs if any one of the specified conditions is met. 


1 


1 
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Table B-5. Branch on Character Condition (BCC) Conditions 



— 

VARIANT CHARACTER 
(Octal) 


BRANCH CONDITION 


00 


Unconditional 


0L':« 


A bit is 1 


02 


B bit is 1 


03=:< 


B and A bits are 11 


04>:< 


B and A bits are 00 


0 5=!< 


B and A bits are 01 (Positive sign) 


06 


B and A bits are 10 (Negative sign) 


07=!' 


B and A bits are 11 (same as 03) 


10 


Word-mark bit is 1 


1 1=!' 


Word- mark bit is 1, A bit is 1 


12 


Word- mark bit is 1, B bit is 1 


13=1' 


Word-mark bit is 1, B and A bits are 11 


14=1' 


Word-mark bit is 1, B and A bits are 00 


15=1' 


Word-mark bit is 1, Positive sign 


16 


Word-mark bit is 1, Negative sign 


17=1' 


Word- mark bit is 1, B and A bits are 11 


20 


Item-mark bit is 1 


21=1' 


Item- mark bit is 1, A bit is 1 


22 


Item- mark bit is 1, B bit is 1 


23=1' 


Item-mark bit is 1, B and A bits are 11 


24=1' 


Item-mark bit is 1, B and A bits are 00 


25=1' 


Item- mark bit is 1, Positive Sign 


26 


Item- mark bit is 1, Negative Sign 


27=1' 


Item-mark bit is 1, B and A bits are 11 


30 


Record mark 


31=1' 


Record mark, A bit is 1 


32 


Record mark, B bit is 1 


33=1' 


Record mark, B and A bits are 11 


34=1' 


Record mark, B and A bits are 00 


35=1' 


Record mark. Positive sign 


36 


Record mark. Negative sign 


37=1' 


Record mark, B and A bits are 11 


40=1' 


No punctuation (Word mark and Record 
mark bits are 00) 


41=1' 


No punctuation, A bit is 1 


42=1' 


No punctuation, B bit is 1 


43=1' 


No punctuation, B and A bits are 1 1 


44=1' 


No punctuation, B and A bits are 00 


45=1' 


No punctuation. Positive sign 


46=1' 


No punctuation. Negative sign 


47=1' 


No punctuation, B and A bits are 1 1 


50=1' 


Word mark 


51=1' 


Word mark, A bit is 1 


52=1' 


Word mark, B bit is 1 


53=1' 


Word mark, B and A bits are 11 


54 = 1 ' 


Word mark, B and A bits are 00 


55=1' 


Word mark, Positive sign 


56=1' 


Word mark. Negative sign 


57='^ 


Word mark, B and A bits are 11 
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Table B-5 (cont). Branch on Character Condition (BCC) Conditions 



VARIANT CHARACTER 




(Octal) 


BRANCH CONDITION 


60>!« 


Item mark 


6 1* 


Item mark, A bit is 1 


62>:< 


Item mark, B bit is 1 


63>i< 


Item mark, B and A bits are 11 


64>:« 


Item mark, B and A bits are 00 


65>!' 


Item mark. Positive sign 


66>!< 


Item mark. Negative sign 


67>!« 


Item mark, B and A bits are 11 


70^< 


Unc onditional 


7LK 


Word mark or A bit is 1 


72^:< 


Word mark or B bit is 1 


73>:« 


Word mark or B and A bits are 11 


74>!< 


Word mark or B and A bits are 00 


75^!^ 


Word mark or Positive sign 


76=:< 


Word mark or Negative sign 


77 .:< 


Word mark or B and A bits are 11 


Valid only on systems equipped with the Advanced Programming Feature 


1 (Feature 010 or Oil). 
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Table B-6. 



Series 200 Character Codes 



Key 

Punch 


Card 

Code 


Central 

Processor 

Code 


Octal 


High 

Speed 

Printer 


Key 

Punch 


Card 

Code 


Central 
Processor 
C ode 


Octal 


High 

Speed 

Printer 


0 


0 


000000 


00 


0 


0 or - 


X, 0 or 


100000 


40 




1 


1 


000001 


01 


1 


J 


X, 1 


100001 


41 


J 


2 


2 


000010 


02 


2 


K 


X, 2 


100010 


42 


K 


3 


3 


000011 


03 


3 


L 


X, 3 


100011 


43 


L 


4 


4 


000100 


04 


4 


M 


X, 4 


100100 


44 


M 


5 


5 


000101 


05 


5 


N 


X, 5 


100101 


45 


N 


6 


6 


000110 


06 


6 


O 


X. 6 


100110 


46 


O 


7 


7 


000111 


07 


7 


P 


X, 7 


loom 


47 


P 


8 


8 


001000 


10 


8 


Q 


X, 8 


101000 


50 


Q 


9 


9 


001001 


1 1 


9 


R 


X. 9 


101001 


51 


R 




8,2 


001010 


12 


1 




X, 8, 2 


101010 


52 


# 


# 


8, 3 


001011 


13 


= 


$ 


X, 8, 3 


101011 


53 


$ 




8, 4 


001100 


14 




❖ 


X, 8, 4 


101100 


54 




Space 


Blank 


001101 


15 


Blank 




X, 8, 5 


101101 


55 


1 1 




8, 6 


001110 


16 


> (2) 




X, 8, 6 


101110 


56 


^ (2) 


& 


8, 7 


001111 


17 


& 


- or 0 


X or X, 0(1) 


101111 


57 


i (2) 


0 or & 


R, 0 or 


010000 


20 


4- 




8, 5>!‘ 


1 10000 


60 


< (2) 


A 


R, 1 


010001 


21 


A 


/ 


0, 1 


1 10001 


61 


/ 


B 


R, 2 


010010 


22 


B 


S 


0,2 


110010 


62 


S 


C 


R, 3 


010011 


23 


C 


T 


0, 3 


110011 


63 


T 


D 


R.4 


010100 


24 


D 


U 


0,4 


1 10100 


64 


U 


E 


R, 5 


010101 


25 


E 


V 


0, 5 


110101 


6 5 


V 


F 


R, 6 


010110 


26 


F 


w 


0, 6 


110110 


66 


w 


G 


R, 7 


010111 


27 


G 


X 


0, 7 


110111 


67 


X 


H 


R, 8 


011000 


30 


H 


Y 


0, 8 


1 1 1000 


70 


Y 


I 


R, 9 


011001 


31 


I 


Z 


0, 9 


111001 


71 


Z 




R, 8, 2 


011010 


32 


; 




0,8,2 


111010 


72 


@ 




R, 8, 3 


011011 


33 




, 


0, 8, 3 


111011 


73 




□ 


R, 8, 4 


011100 


34 


) 


% 


0, 8, 4 


111100 


74 


( 




R, 8, 5 


011101 


35 


% 




0,8, 5 


111101 


75 


Cr 




R, 8, 6 


011110 


36 


■ 




0,8,6 


111110 


76 


□ (2) 


& or ^ 


R or R, 0^^^ 


011111 


37 


9(2) 




0,8,7 


111111 


77 


^ (2) 



( 1 ) 

( 2 ) 



Special Code, This card code-central processor code equivalency is effective when control 
character 26 is coded in a card read or punch PCB instruction. 

Indicates symbol which will be printed by a printer which has a 63-character drum (Type 222 printers). 
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Table B-7. Binary, Octal, and Decimal Equivalents 



Table B-8. Powers of 2 



BIN. 


OCT. 




mm 


OCT. 


0 


0 


0 


100000 


40 


1 


1 


1 


100001 


41 


10 


2 


2 


100010 


42 


11 


3 


3 


100011 


43 


100 


4 


4 


100100 


44 


101 


5 


5 


100101 


45 


1 10 


6 


6 


100110 


46 


1 1 1 


7 


7 


loom 


47 


1000 


10 


8 


101000 


50 


1001 


1 1 


9 


101001 


51 


1010 


12 


10 


101010 


52 


1011 


13 


1 1 


101011 


53 


1100 


14 


12 


101100 


54 


1101 


15 


13 


101101 


55 


1110 


16 


14 


101110 


56 


nil 


17 


15 


101111 


57 


10000 


20 


16 


1 10000 


60 


10001 


21 


17 


1 10001 


61 


10010 


22 


18 


110010 


62 


10011 


23 


19 


noon 


63 


10100 


24 


20 


110100 


64 


10101 


25 


21 


110101 


65 


10110 


26 


22 


110110 


66 


10111 


27 


23 


110111 


67 


11000 


30 


24 


111000 


70 


11001 


31 


25 


111001 


71 


11010 


32 


26 


111010 


72 


non 


33 


27 


111011 


73 


1 1100 


34 


28 


111100 


74 


11101 


35 


29 


111101 


75 


lino 


36 


30 


111110 


76 


11111 


.JL 


31 


111111 


77 



n 


2" 


0 


1 


1 


2 


2 


4 


3 


8 


4 


16 


5 


32 


6 


64 


7 


128 


8 


256 


9 


512 


10 


1 024 


1 1 


2 048 


12 


4 096 


13 


8 192 


14 


16 384 


15 


32 768 


16 


65 536 


17 


131 072 


18 


262 144 


19 


524 288 


20 


1 048 576 


21 


2 097 152 


22 


4 194 304 


23 


8 388 608 


24 


16 777 216 
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INSTRUCTION SUMMARY 
Table C-1. Instruction Summary 



Card Key Function 

Octal Code Punch ^ 



Tinning 

(Memory Cycles) 



ARITHMETIC INSTRUCTIONS 





36 


R, 8. 6 




Decimal Add 


Nj+2+N^+2N^j (no 
recomplement) ^ 

Nj+2+N^+4Njj 
(re complement)^ 


37 


R or R, 


& 


Decimal Subtract 


N.+2+N +2N. (no 
r.JcompYenreSo'l 
N.+2+N +4N. 
(recomplement)^ 


34 


R, 8, 4 


l~Q 


Binary Add 


Ni+ltNw+2N^ 


35 


R, 8, 5 




Binary Subtract 


Nj+1+N^+2N^ 


16 


8, 6 




Zero and Add 


N^+l+N^ l-N^^ 


17 


8. 7 




Zero and Subtract 


Ni+1 l-Nw+Nb 


26 


R. 6 


F 


Decimal Multiply 


See page 8-28. 


27 


R, 7 


G 


Decimal Divide 


See page 8- 3 1 ••• 













a. BA/A, B 

b. BA/A 

c. BA/ 

a. BS/A, B 

b. BS/A 
c- BS/ 

a. ZA/A, B 

b. ZA/A 

c. ZA/ 

a. ZS/A, B 

b. ZS/A 

c. ZS/ 

a. M/A, B 

b. M/A 

c. M/ 



LOGIC INSTRUCTIONS 



Duplicates 

A. 


B operand. A B-operand 
operand only if word mark 
smaller than B. 


Duplicates 

A. 


B operand. A B-operand 
operand only if word mark 
smaller than B. 


Duplicate s 
A. 


B operand. A B-operand 
operand only if word mark 
smaller than B. 


Duplicate s 
A. 


B operand. A B-operand 
operand only if word mark 
smaller than B. 


Duplicates 

A. 


B operand. A B-operand 
operand only if word mark 
smaller than B. 


Duplicates 

A. 


B operand. A B-operand 
operand only if word mark 
smaller than B. 


Preserves 







31 


R. 9 




Extract (Logical 
Product) 


N. H+3N^ 


30 


R, 8 


H 


Half Add 
(Exclusive Or) 




32 


R, 8, 2 




Substitute 


Ni+4 


33 


R, 8, 3 




Compare 


N^+2+N^+N 


65 


0, 5 


V 


Branch 

(Unconditional) 


Ni+2 


65 


0, 5 


V 


Branch on 
Condition Test 


Nj+aS 


54 


X, 8. 4 




Branch on 
Character 
Condition 


Ni+4 


55 


X, 8, 5 




Branch if 
Character Equal 


Ni+4 


56 


X, 8, 6 




Branch on Bit 


Ni+4 




b. EXT/A 

c. EXT/ 


B. 


and. 


of smaller 
operand. 




a. HA/A, B 

b. HA/A ! 

c. HA/ 


Preserves 

B. 


Smaller oper- 
and. 


Word mark 
of smaller 
operand. 


Yes. 


a. SST/A, B, V 

b. SST/A, B*' 

c. SST/A 

d. SST/ 


Preserves 

B. 


None. 


Single- 

character 

operation. 


Yes. 


a. C/A, B 

b. C/A 

c. C/ 


Preserves 

B. 


B operand. A 
operand only if 
smaller than B. 


B-operand. 
word mark. 


Yes. 


a. B/A 


Bypasses 

B. 


None. 


n/a 


No. 


a. DCT/A, 

b. BCT/ 


Bypasses 

B. 


None. 


n/a 


Yes. “ 


a. BCC/A, B, 

b. BCC/A, B 

c. BCC/A 

d. BCC/ 


Preserves 

B. 




Single - 

character 

operation. 


Yes, 


a. BCE/A, B, 

b. BCE/A, B 

c. BCE/A 

d. BCE/ 


Preserves 

B. 


None. 


Single- 
characte r 
ope ration. 


Yes. 9 


a. BBE/A, B. V 

b. BBE/A, B 

c. BBE/A 

d. BBE/ 


Preserves 

B. 




Single - 

character 

operation. 


Yes. 



CONTROL INSTRUCTIONS 



a. SW/A, B 

b. SW/A 

c. SW/ 


Duplicates 

A. 


None . 


n/a 


a. SI/A, B 

b. SI/A 

c. SI/ 


Duplicates 

A. 


None . 


n/a 


a. CW/A, B 

b. CW/A 

c. CW/ 


1 unlicates 

A. 


Word marks 


n/a 


a. Cl/ A, B 

b. CI/A 

c. Cl/ 


Duplicates 

A. 


None . 


n/a 


a. H/“ 

b. H/A 

c. H/A. B 

d. H/A. B. V 


Preserves 

B. 


None. 


n/a 


a. NOP/ 


Bypasses 
A and B. 


None. 


n/a 


a. MCW/A, B 
be MCW/A 
c. MCW 


Preserves 

B. 


Smaller 
operand . 


Word mark 
of smaller 
operand. 


a. LCA/A, B 

b. LCA/A 

c. LCA/ 


Preserves 

B. 


A operand. 


A-operand 
word mark 


a. SCR/A, V7 

b. SCR/A 


Bypasses 

B. 


None. 


n/a 















INSTRUCTION SUMMARY 



LCR 25 R,5 

CAM 42 X, 2 

CSM 43 X, 3 



MAT 60 8,5 



MIT 62 0,2 



LIB 77 0,8,7 



SIB 76 0,8, 6 



E Load Control 

K Change Addres 
ing Mode 

L Change Sequen 
ing Mode 



CONTROL INSTRUCTIONS (cont) 

a. L.CR/A, V’’ Bypas 

b. LCR/A B 

c. LCR/ 



Ni+3Na‘3 

Nj+Na+2(N^t) (NBy) 



Load Index/ 

Barricade 

Register 

Store Index/ 

Barricade 

Register 



a. CAM/V"^ Bypasses None, 

b. CAM/ A and B. 

a. CSM/^^ Preserves None. 

b. CSM/A B. 

c. CSM/A, B 

d. CSM/A, B, V 

a. EXM/A, B, v5 Preserves .See page 8-74. 

b. EXM/A, B B. 

c. EXM/A 

d. EXM/ 

a. MAT/A3 ,Vj,V 2 Sec page A operand. 

8-77. 

a. MIT/A,B, See page None. 

V,, V,, V, 8-80. 



Preserves None. 

B. 

Preserves None. 



Wordmark 
in A operand 
or in table. 
A-operand 
item mark or 
word mark in 
table. 



SVI 


46 


X,6 


0 


Store Variant 
and Indicators 


Ni+1+N,+Nj 


RVI 


67 


0, 7 


X 


Restore 
Variant and 
Indicators 


N(+2+N,‘‘ 


MC i 


44 


X, 4 


M 


Monitor Call 


Ni+Z"! 


RNM 


41 


X, 1 


J 


Resume 
Normal Mode 





INTERRUPT CONTROL INSTRUCTIONS 



. SVI/V 



a. RVI/A, V Restores None. 

A and 
bypasses 



a. RNM/A.B 

b. RNM/A 

c. RNM/ 




EDITING INSTRUCTION 



a. MCE/A, 

b. MCE/A 

c. MCE/ 



INPUT/OUTPUT INSTRUCTIONS 




W Peripheral 
Data 



Peripheral 
Control and 
Branch 



PDT/A, C|,.C^ 



a. PCB/A, Ci... C„ 




^Except where otherwise indicated, add one memory cycle to each of these formulas if the instruction is being executed in a Type 2201 pr 
2The extraction path of the various instructions is defined as follows: 

• Preserves B - The previous contents of BAR are used as the B address when the instruction is coded in the format Op Code/A. 

. Duplicates A - The contents of AAR are used as the B address when the instruction is coded in the format Op Code/A. 

• Bypasses B - The contents of BAR are not used in any format. 

• Bypasses Aand B - The contents of AAR and BAR are not used in any format. 



, Card Read or Punch PCB instruction. 



^The second (alternate) card code is in effect when control character 26 is coded in a Card Read or Punch PCB instruction. 

^Subtract one memory cycle from this formula if the instruction is being executed in a Type 1201 processor. 

^This instruction can be coded only in formats a. and d. when issued in a Type 201 or 201-1 processor. 

^Add two memory cycles to this formula if the instruction is being executed in a Type 2201 processor. 

^This instruction can be coded only in format a. when issued in a Type 201 or 201-1 processor. 

®This instruction cannot be chained in the Type 201 or 201-1 processor. 

"^This instruction can be chained in the Type 201 or 201-1 processor only if the preceding instruction Is also a BCE instruction. 

^^Subtract one memory cycle from this formula if the instruction is issued in the Type 1201 processor in the format Op Code/A, B. 

^ ^This instruction can be coded only in formats a. , b. , and c. when issued in a Type 201 or 201-1 processor. 

^^Subtract one memory cycle from this formula if the instruction is executed in a Type 1201 processor. 

^^Add four memory cycles to this formula if the instruction is executed in a Type 2201 processor. 

^^Add two memory cycles to this formula if the instruction is executed in a Type 1201 processor. Add four cycles to the formula if the instruction is executed in a Type 
2201 processor. 

^^Add one memory cycle to this formula if the instruction is executed in a Type 1201 processor. Add two cycles to the formula if the instruction is executed in a Type 2201 
^^Add two memory cycles to this formula if the instruction is executed in a Type 2201 processor. Subtract one memory cycle from the formula if the instruction is executed 
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APPENDIX I 

INTERRUPT PROCESSING 

The execution of main-program instructions by the processor can be interrupted by an 
external interrupt source and, if the processor is a Type 1201 or 2201 with the Storage Protect 
Feature (see Appendix E), by an internal interrupt source. 

EXTERNAL INTERRUPT 

An external interrupt signal can be generated by any one of three sources: 

1. a peripheral control (including data communication controls); 

2. the operator's control panel or console; or 

3. the Monitor Call instruction (see page 8-95). 

The interrupt signal sets indicators to show the source (whether 1. , 2. , or 3. , above) 
and the type (external) of interruption. These indicators can be stored and tested by pro- 
grammed instruction as described further in this appendix. The processor acts upon the in- 
terrupt signal when the following conditions are present: 

1. The processor is in the RUN mode (i.e., the processor is executing, without 
manual intervention, stored-program instructions under control of SR). 

2. The processor is not in the external interrupt mode. 

3. An instruction op code is about to be extracted. 

4. A memory cycle is allocated to the processor. 

It should be noted that condition 3, above does not cause an extensive delay if a Type 
201-2, 1201, or 2201 processor is attempting to extract a Peripheral Data Transfer (PDT) 
instruction and the specified read/write channel or peripheral control is "busy. " The attempt 
to issue a PDT instruction to a busy read/write channel or peripheral control does not "stall" 
the central processor. Rather, the instruction is "re-extracted": SR is set back to the 
address of the PDT op code, so that condition 3. recurs immediately after the channel or con- 
trol is found busy. 

The interrupt signal is maintained by the source until the processor responds by taking 
the following actions: 

1. The current status of the arithmetic, comparison, address mode, 
and trap mode indicators are stored in the auxiliary indicators 
register (AIR). 
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2. The arithmetic indicators are cleared. 

3. The processor enters the three-character, non-trap mode. 

4. The contents of SR and EIR are interchanged, and the program branches 
to the instruction whose op code address was previously stored in EIR. 

5. The processor enters the external interrupt mode. 

INTERNAL INTERRUPT 

An internal interrupt signal is generated only by a Type 1201 or 2201 processor equippedwith 
the Storage Protect Feature and is caused by a "violation” of storage protection. (The nature 
of storage protect violations — II address violation, op code violation, etc. — is described 
in Appendix E. ) Processor indicators are set by the internal interrupt signal to show the 
cause (e.g. , op code violation) and the type (internal) of interruption. These indicators can be 
stored and tested by programmed instruction as described further in this appendix. 

The processor reacts to the internal interrupt signal when the conditions described on 
page D- 1 are present (i. e. , the processor is in the RUN mode, is not in the external interrupt 
mode, is about to extract an op code, and is presently allocated a memory cycle) plus one 
additional condition: the processor must not only not be in the external interrupt mode but 
also must not be in the internal interrupt mode. Thus, the following levels of interrupt 
priority exist in the Type 1201 or 2201 processor: 

1. If the processor is in the non -interrupt (standard) mode, normal program 
sequence can be interrupted by either an external or an internal source. 

2. If the processor is in the internal interrupt mode, program sequence 
can be interrupted only by an external interrupt source. 

3. If the processor is in the external interrupt mode, program sequence can not 
be interrupted. 1 

The processor responds to an internal interrupt signal as follows; 

1. The contents of SR and HR are interchanged, and the program branches 
to the instruction whose op code address was previously stored in HR. 

2. The processor enters the internal interrupt mode. 



^Interrupt signals generated by any or all of the three external sources (peripheral control, 
control panel or console, or Monitor Call instruction) may continue to occur while the 
processor is in the external interrupt mode. The priority in which the processor responds 
to these sources is determined by the program (i. e. , according to the programmer - 
established sequence of interrupt source tests). 
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Note that the status of the arithmetic, comparison, address mode, and trap mode indicators 
are not stored in AIR automatically when the processor responds to an internal interrupt 
signal. The storing (and subsequent restoring) of the contents of these indicators is the 
responsibility of the internal interrupt program. 



INTERRUPT PROGRAMMING 

Three of the four interrupt control instructions (pages 8-90 through 8-97) perform 
basic functions in an interrupt routine: 

1. The Store Variant and Indicators instruction (SVI) stores two types of 
information: (a) information which must be preserved for subsequent 
return to the interrupted program (e. g. , indicator settings, variant 
register contents, etc. ); and (b) information required to identify the 
interrupt source. 

2. The RestoreVariant and Indicators instruction (RVI) restores the pertinent 
information stored by the SVI instruction before returning to the interrupted 
program. 

3. The Resume Normal Mode instruction (RNM) returns the processor to 
the interrupted program. 



The fourth interrupt control instruction — Monitor Call (MC) — causes an external interrup- 
tion and is therefore not coded in the interrupt routine itself. Other instructions are required 
in the interrupt routine to store and exercise control over address register contents, as shown 
in Figures D-1 and D-2. 



EASYCODER 

CODING FORM 



PROBLEM PROGRAMMER DATE PAGE OF 



CARD 

NUMBER 


I 


LOCATION 


OPERATION 

CODE 


OPERANDS 




1 2 1 3 4l 5 


iD 


8 , 14 


I5| . , . .20 


1 .... 1 .... 1 . 1 1 . 1 , 1 


63 , , . , . , .80 


■ |.| 




A^R, . . . 


CEQU 




iMmmMmM 






BAR , , , 




♦^Vc.70, ...... ,B~AD.D,RES,S, RE,G,I,STER , , . 




. . 1 




MAy, 


aaasm 




— 


, , 1 




ALLS 


assn 






1 1 
. 1 . 1 




ALLR. . , 








- [■ ... u 












1 

. 1 . 




restor 




EN.TER-t:2,.AL,L.R RESTORE, ALV-. BUT. .INT... .IMP.. , , , 




ilHH 




ekut 








MU 






^sm 


AU.S. , . . . , , . .E.M,T.E)g. AK),D .S.TiO.RE, ALJ-. JWP.LCATOR 


s. . , . . . . 


■M 










S, .... 1 ... . 


:BHH 












HM 






S.C.R . . 


EAI.T.4-,3 ,AREG. . SAVE. AAR 


■mmmim 


mm 






SCR . . 


EXIT,iC.;.BREG . .SAVE BAR , , , 


. . 1 


■n 






,( 




.. i 1 .... 1 .... ' . 




. i . 1 










... 1 .... 1 .... 1 .... 1 .... 1 .... 1 . 




m 










. exterwal 




H| 






,1 




f. IWTERRUP.T. . . , . 




HI 










. ,RQMT\M,E; 




■M 






w 




^ -1 . . . ^ 1 ■ . ■ . i . ^ ^ . 1 . . . . 1 . 




mi 








[sHEEBimm 


. i \ i i , 1 ■ ■ . . 



Figure D-1. Sample Coding For External Interrupt Routine 
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The first example (see Figure D-1) shows the initial and final coding to be used in an 
external interrupt routine. It is assumed that the address tagged ENTER was previously stored 
in EIR, so that the presence of an external interrupt signal results in the automatic branch to 
the location tagged ENTER. It is assumed that the four -character addressing mode is the 
maximum addressing mode of the processor for which this routine is written. 

NOTE: If the interrupt routine is not in the maximum addressing mode prior to 

branching to the location tagged RESTOR, a Change Addressing Mode 
instruction — CAM/MAX — must precede the RVI instruction so that 
the complete contents of any necessary control memory locations may 
be restored. 



Figure D-2 shows the initial and final coding written for an internal interrupt routine. 

It is assumed that the address tagged START was previously stored in HR and that the maximum 
addressing mode of the processor is the four -character mode. 

EASYCODER 

CODING FORM 



PROBLEM PROGRAMMER DATE PAGE OF 



CARD 

NUMBER 


15 


1 LOCATION 


OPERATION 

CODE 


OPERANDS 




1 2 |3 4l 5 


6 


8 1 . . .14 


I5| . , .20 


1 ..... 1 .... 1 . 1 1 . , 1 


. I ...... . ..... .80 


1 , 1 








‘^1.C,6,7 . A- .ADDRESS RE,G.l.STER . , , 












....... .5’ ADDRESS .REGISTER 
















HD 












BhB! 




I.NDR 




«:1.C.3.3, AIL bUT AIR AMD l,MT. .IMDICATO 


RS. 


HHI 




SAVEA . 




^AC .T.EMP.O.RAR,y. ,S.TP,RK6,E ,FD,R ,AAR. . , . 








■ 








mi 




- ^ . 1 . . . 








nu 




RES, TOR 


lam 






HHI 








SAVEBijBAR , RESTORE, BAR , . . . , 




HHI 








START+.2,,.\.N,D,R .RE,S.T.0R.E, ALU. ,BUT. AIR AN.D IMT, 1 


'iO. 


MH 








.e.x,\t. . 




■n 






^im 






mm 


1 


HHMI 








mu 


1 










1 1 






S,CR 


SAVEAi.AA.R , . .SAVE AAR , , , . , . , , . 




-44- 






5,CR 


3AV.E.B..BAR. , . . .SAVE BAR , . . , . 




. I ■ 






4 




1 . . . T 






. 1 . 1 













1 ...< 1 .... 1 .... 1 1 .... 1 . 




1 










______ 






-4-4 






4 


. . . 


.... 1 ... .^ .mTERRUPT, .R0UT,\VAE , , , 




-44- 






-d 








. 1 






4 








' 1 ■ 1 






g) . . . . 


EE.SJ0R . ■ . , , , .BRARCH. ,T.Q RESTQR ,AND E,)C.IT. . , . 


i 1 1 1 1 1 1 1 » ■ ■ ■ 1 -L-_l - _1 1 



Figure D-2. Sample Coding For Internal Interrupt Routine 



The initial and concluding instructions in an internal interrupt routine are similar to those 
in an external interrupt routine, except that the SVI instruction must not store the contents of 
the auxiliary indicators register (AIR), All other pertinent indicators are stored by the SVI 
instruction and are subsequently restored by the RVI instruction at the conclusion of the routine. 
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Another difference between the coding of the two routines is that the RNM instruclion 
is coded in the internal interrupt routine in the fornaat RNM/ (i. e, , no address portions). 
The stored contents of AAR and BAR are therefore restored by two LCR instructions, issued 
in the maximum addressing mode of the processor, which immediately precede the RVI in- 
struction. 
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STORAGE PROTECT FEATURE 




When the Type 1201 or 2201 processor is equipped with the Storage Protect Feature, 
the main memory can be logically divided into two distinct areas: an "open" area and a "pro- 
tected area. When storage protection is in effect, the contents of the protected area are 
shielded from unintentional interference by a program stored in the open memory area. The 
boundaries of the protected memory area are specified as follows: 

1. The lower boundary is set by the Load Index/Barricade Register instruction 
(LIB) which specifies the number of a 4, 096 -character memory bank. This 
number is loaded into the index/barricade register and is the number of the 
bank whose leftmost location is the boundary of the protected area. 

2. The upper boundary of the protected area is the rightmost location of the 
main memory. 



Index registers 16 through 30 are contained in the leftmost 60 locations of the 4, 096- 
character bank specified in the LIB instruction. Thus, the locations of these registers are 
redefined when the contents of the index/protect register are altered by an LIB instruction. 



The following conditions must be present for storage protection to be in effect: 

The protect indicator is on. (The protect indicator can be set by the execution 
of the Restore Variant and Indicators instruction — see page 8-93. ) 

2. The processor is neither in the external interrupt mode (see Appendix D) nor 
in the internal interrupt mode (see below). 



INTERNAL INTERRUPT 

When storage protection is in effect (i.e. , the two conditions specified above are 
present), certain operations are defined as "violations" of that protection. Such violations are 
discussed further in this appendix. The violation causes an indicator to be set which, in turn, 
causes an internal interrupt to occur at the next opportunity. The "next opportunity" means that 
moment when all of the following conditions are present: 

1 . The processor is in the RUN mode (i. e. , the processor is executing, 
without manual intervention, stored-program instructions under control 
of SR). 

2. The processor is about to extract an op code. 

3. A memory cycle is allocated to the processor. 

4. The processor is neither in the external interrupt mode nor in the internal 
interrupt mode, and no peripheral or control panel interrupt signal is being 
received. 
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The activation of the internal interrupt mode is similar, but not identical, to the proc- 
essor's actions taken when an external interrupt signal is received (see Appendix D). Three 
basic differences exist between the two interrupt modes. First, a unique control memory- 
location — the internal interrupt register (UR) — is used to contain the address of the sub- 
routine which services the internal interrupt. (IIR is designated by a variant character of 46 

8 

in a Store Control Registers or Load Control Registers instruction — see page 8-65.) 

Secondly, the processor is still subject to being interrupted by an external interrupt while it is 
in the internal interrupt mode. 



The third difference between the internal and external interrupt modes is that no processor 
indicators are stored or changed when the internal interrupt mode is entered; the handling of 
processor indicators in the internal interrupt mode is the programmer's responsibility (using 
the Store Variant and Indicators and the Restore Variant and Indicators instructions — see 
pages 8- 90). 



VIOLATIONS OF STORAGE PROTECTION 

The following operations are violations of storage protection: 

1. An attempt to transfer information internally to a main memory location 
contained in the protected memory area (i. e. , not ci peripheral transfer 
attempt) . 

Although information transfers to the protected memory area cause a 
violation, there is no restriction on the transfer of information from 
the protected area. In particular, the protected index registers (index 
registers 16 through 30) can be used for indexing by programs in either 
the open or protected areas. However, modification of the contents of 
these registers is inhibited and causes a violation. 

When either of the above -mentioned violations occurs, the II address 
violation indicator is set. The instruction which causes the violation 
proceeds normally in all other respects, and the internal interrupt 
occurs only after the completion of such an instruction. 

2. An attempt to extract a Peripheral Data Transfer (PDT) instruction 
whose effective A address references a protected memory location. ^ 

Once it is determined that the effective A address references a protected 
main memory location, no operation is performed (i.e. , the specified 
read/write channel is not tested, and the specified peripheral control is 
not addressed). The II address violation indicator is set, the contents 

of SR are advanced to the next sequential op code, and the instruction 
is terminated without ever having been executed. The internal interrupt 
occurs at the completion of the instruction. 



^A PDT instruction is one of eight instructions whose execution is normally prohibited 
when storage protection is in effect. However, the proceed indicator can be set to 
permit the execution of this instruction (see page E-3). Thus, for a PDT instruction to 
be extracted (andtherefore to reach the stage where the A address of the instruction is 
tested), the proceed indicator must first be set to allow the extraction of the instruction. 
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Note that a PDT instruction is checked for a possible violation during the extraction 
of that instruction, while a non -peripheral instruction is checked during its 
execution (as in 1 . , above). If a PDT instruction passes this test during its 
extraction, it is free to be executed and thereby cause data to be transferred. 

If the record being transferred extends into the protected memory area, a 
violation does not occur. To prevent such a record (i, e. , one whose 
effective A address does not reference the protected area, but a portion of 
the record transferred extends into the protected area), record marks should 
be set in both the first and last locations of the protected memory area. 

3. An attempt to transfer information from a main memory location that is 
within the addressing capacity of the memory address register of the user's 
processor, but which is greater than the capacity of the main memory actually 
present in the machine. ^ Such an addressing attempt would normally cause 
the machine to halt due to a parity-check error. However, when storage 
protect is in effect, such an error does not cause a halt, nor is data trans- 
ferred into the memory with "bad parity. " Instead, the II address violation 
indicator is set, and the internal interrupt occurs at the completion of the 
instruction. 

4. An attempt to execute an instruction whose op code is: (a) not defined for 

the Series 200; (b) not recognized by the user's processor; or (c) 
prohibited when storage protection is in effect. Prohibited op codes 
under this condition are the following: 

a. H (Halt) 

b. LCR (Load Control Registers) 

c. PDT (Peripheral Data Transfer) 

d. PCB (Peripheral Control and Branch) 

e. SVI (Store Variant and Indicators) 

f. RVI (Restore Variant and Indicators) 

g. RNM (Resume Normal Mode) 

h. LIB (Load Index/Barricade Register) 

The detection of any of the above-listed op codes sets the op code violation 
indicator and causes the contents of SR to be set back to the location of 
the op code which was the offender. The operation is terminated, and 
the internal interrupt occurs subject to the other conditions whose presence 
is required for the internal interrupt to occur (see page E-1). 



PROCEED INDICATOR 

The proceed indicator can be turned on through the execution of the Restore Variant 
and Indicators (RVI) instruction (see page 8-93). When the proceed indicator is on, one 
instruction is permitted to be executed in the non-interrupt mode without : (1) op code 
checking; or (2) item mark trapping. In other words, both op code checking and item mark 



^The memory address register contains as many bits as are necessary to address the 
memory of an individual processor. Thus, a processor whose main memory capacity 
is 32, 768 characters contains 15 bits in the memory address register; a memory capacity 
of 65, 536 characters requires 16 bits in the register. If a processor has a memory capacity 
of, for example, 49,152 characters, the memory address register must still contain 16 
active bits in order to address memory locations above 32, 768. In this case, the capacity 
of the main memory actually present in the processor (49, 152) is less than the addressing 
capacity of the memory address register (65, 536). Thus, a location can be addressed 
which is within the range of the register but which is not actually present in the user's system. 
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trapping are overruled by a proceed indicator which is turned on. The proceed indicator is 
turned off by the execution of any instruction in the non -interrupt mode. 



The proceed indicator may also be used to enforce the A address checking of a PDT in- 
struction issued in the interrupt mode (either the external or internal interrupt mode). 

Thus, when the following conditions are present: 

1. the processor is in either interrupt mode; 

Z. the proceed indicator is turned on; 

3. a PDT instruction is extracted; 

the A address of the PDT instruction is checked for violation as described on page E-2. 

If the effective A address references a protected memory location, the actions described below 
are performed. 

1. When the violation occurs in the internal interrupt mode: 

a. The II address violation indicator is set. 

b. Further extraction of the instruction is not performed, and the contents 
of SR are advanced to the next sequential op code. 

c. An internal interrupt does not occur (since the processor is already 

in the internal interrupt mode). Rather, the condition of the II address 
violation indicator may be tested by the program (after the status of 
of the indicator is stored via an SVI instruction). The execution of 
the SVI instruction clears the indicator, so that the setting of this 
indicator does not eventually cause an internal interrupt. 

2. When the violation occurs in the external interrupt mode: 

a. The El address violation indicator is set. 

b. No further extraction is performed, and the contents of SR are 
advanced to the next sequential op code. 

c. An internal interrupt does not occur (since the processor is in the 
external interrupt mode). Rather, the condition of the El address 
violation indicator can be tested after an SVI instruction is issued 
as described in l.c., above. 
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SCIENTIFIC UNIT FOR MODELS 1200 AND 2200 



The scientific unit (Feature 1100) provides a repertoire of 12 floating-point instructions, 
a binary mantissa shift instruction, and a binary integer multiply instruction for the Type 1201 
or 2201 processor. This appendix is a programmer's working summary of the hardware bulletin 
Scientific Unit fo r Models 1200 and 2200, Feature 1100 (File No. 112.0005. 1539.00. 00). Before 
referring to this appendix, the programmer should be familiar with the detailed functional and 
programming description of Feature 1100 presented in the hardware bulletin. 




DATA FORINT 

The fixed-length floating-point word contains a 36-bit binary mantissa and 12-bit binary 
exponent and is capable of expressing numbers in the approximate range ±10*^^^. 



CHARACTER 



A-7 



A-6 



A- 5 



A-4 



BIT B A84 2 I B 
N 



A-3 



A-2 



I B 



A-l 



I B 



I B 



I B 



I B 



MANTISSA 






"extonent 



In control memory, a floating-point word may occupy any of the four floating-point ac- 
cumulators. The accumulators are addressed as octal digits 0, 1, 2, and 3 in the floating-point 
instructions. Each accumulator comprises three specific 18 -bit control memory registers. 

Only the low-order 12 bits of the rightmost register are used to express the exponent. 



BIT 



18 



MANTISSA 





+ 











18 



12 



EXPONENT 



FLOATING-POINT REGISTERS 

The four addressable floating-point accumulators have the locations in control memory 
shown on page F-2. 
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Accumulator 

Address 


Control Memory Location (Operator's Control Panel Only) 


High-Order Mantissa 


Low-Order Mantissa 


Exponent 


0 


43 


42 


41 1 


1 


47 


46 


45 


2 


53 


52 


51 


3 


57 


56 


55 



NOTE ; In program instructions, the floating-point accumulators may be ad- 
dressed only via the octal digits 0, 1, 2, and 3 in the floating-point 
instructions. The instructions LCR and SCR cannot be used to ad- 
dress these accumulators. At the control panel, the operator may 
address these locations with the addresses in the above table. 



A normal zero, i. e. , a floating-point word of 48 zeros, is stored in the "pseudo ac- 
cumulator" for use as a floating-point operand. The pseudo accumulator, which is addressed 
by octal digit 7, may be used only as the source of a normal zero and not as the destination of 
a floating-point result. 

The low-order result register (LOR) in the scientific unit may contain a low-order sum, 
difference, or product, or may contain the remainder of a division operation. 



FLOATING-POINT INDICATORS 



Exponent 

Overflow; 



Divide 

Check; 



Activated when a base -2 exponent exceeds +2047. The correct mantissa and an 
exponent which is 4096 less than the correct exponent are delivered. If an ex- 
ponent is less than -2048, a normal zero is delivered automatically. 

Activated when a divisor is equal to zero. This indicator causes termination 
of a division operation without accumulator alteration. 



Multiply Activated when the product of a Binary Integer Multiply instruction exceeds 24 

Overflow; bits in length. The low-order 24 bits are delivered. 



AUTOMATIC FORMATTING IN ARITHMETIC OPERATIONS 

Pre-normal- Mantissa of divisor is normalized (left- shifted) with adjusted exponent, 
ization; 



Equali- 

zation; 

Post-nor- 

malization; 



Mantissa of operand with smaller exponent is right-shifted until exponents are 
equal. 

Mantissa of result is normalized with adjusted exponent. 



SYMBOLOGY 

A; A address of the instruction. 

B; B address of the instruction. 

X; Floating-point accumulator addressed in the high-order three bits of an instruc- 

tion variant (usually the source of an operand). 
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Y: 

(A): 

(X) or (Y): 

LOR: 

(LOR); 

Ap‘. 

Bp: 

JI: 

NXT; 

Nn: 

Ni: 

[] = 

X-; 



-Y: 

SP; 

DP; 

SR: 

Ni: 



Floating-point accumulator addressed in the low-order three bits of an instruction 
variant (usually the destination of a result). 

Floating-point word contained in the main memory field from character A through 
character A-7. 

Floating-point word contained in accumulator X or Y. 

Low-order result register. 

Floating-point word contained in LOR. 

Previous setting of A-address register. 

Previous setting of B-address register. 

Address of next instruction if branch occurs. 

Next sequential instruction. 

Number of bit positions shifted for automatic formatting. 

Number of binary ones in a multiplier. 

Number of shifts. 

"smallest integer greater than" 

In the first variant of an instruction, only the high-order three bits specifying 
accumulator X are significant. 

In the first variant of an instruction, only the low-order three bits specifying 
accumulator Y are significant. 

Single -precision. 

Double - precision. 

Sequence register. 

Number of characters in an instruction. 



TIMING NOTES 

All timings shown are for Model 2200 and are based on the use of direct addressing. 
Three memory cycles should be added for each indexed address and one memory cycle should 
be added for each character extracted as a result of indirect addressing. 
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Table F-1. Summary of Scientific Instructions 



FORMAT 


OCTAL 

OP 

CODE 


FUNCTION 


REGISTERS 

AFTER 

OPERATION 


TIMING 1 




DATA MOVING INSTRUCTIONS 




STORE FLOATING ACCUMULATOR 














FMA/A, X-, 00 
or 

TAM/A, X- 


07 


(X) is stored in (A). 
(X) is unaltered. 


AAR: A-8 
BAR; Bp 


Ni + 10 cycles 




LOAD FLOATING ACCUMULATOR 












Memory to 
accumulator 


FMA/A, -Y, 02 
or 

TMA/A, -Y 


07 


(A) is loaded into Y. No 
normalization occurs. 


AAR; A-8 
BAR; Bp 


N^ + 1 1 cycles 




Accumulator to 
accumulator 


FAA/XY, 02 
or 

TAA/XY 


06 


(X) is loaded into Y. No 
normalization occurs. 


AAR; Ap 
BAR; Bp 


8 cycles 




1 STORE LOW-ORDER RESULT 












Memory to 
accumulator 


FMA/A, 00, 07 
or 

TLM/A 


07 


(LOR) is stored in A. No 
normalization occurs. 


AAR; .A-8 
BAR; Bp 


Nj + 9 cycles 




Accumulator to 
accumulator 


FAA/ -Y, 07 
or 

TLA/-Y 


06 


(LOR) is stored in Y. No 
normalization occurs. 


AAR; Ap 
BAR; Bp 


6 cycles 




LOAD LOW -ORDER 


RESULT 












Memory to 
accumulator 


FMA/A, 00, 01 
or 

TML/A 


07 


(A) is loaded into LOR. No 
normalization occurs. 


AAR; A-8 
BAR; Bp 


Nj^ + 9 cycles 




Accumulator to 
accumulator 


FAA/X-, 01 
or 

TAL/X- 


06 


(X) is loaded into LOR. No 
normalization occurs. 


AAR; Ap 
BAR: Bp 


6 cycles 
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Table F-1 (cont). Summary of Scientific Instructions 



FORMAT 


OCTAL 

OP 

CODE 


FUNCTION 


REGISTERS 

AFTER 

OPERATION 


FLOATING POINT ARITHMETIC INSTRUCTIONS 


FLOATING ADD 








Memory to FMA/A, XY, 10 


07 


(A) is added to (X) and the 


AAR: A-8 


accumulator or 




sum is stored in Y. 


BAR: Bp 


AMA/A, XY 




Indicator: Exponent overflow. 


LOR: Low-order result 






Formatting: Equalization, 


of operation. Sign 






post- normalization. 


bit = 0. Exponent = 








high-order exponent 








minus 35. 


Accumulator to FAA/XY, 10 


06 


(X) is added to (Y) and the 


AAR: Ap 


accumulator or 




sum is stored in Y. 


BAR: Bd 


AAA/XY 




Indicator: Exponent overflow. 


LOR: Low-order result 






Formatting: Equalization, 


of operation. Sign 






post- normalization. 


bit = 0. Exponent = 








high-order exponent 








minus 35. 


FLOATING SUBTRACT 








Memory to FMA/A, XY, 11 


07 


Twos complement of (A) is 


AAR: A-8 


accumulator oi* 




added to (X) and the result 


BAR: Bd 


SMA/A, XY 




is stored in Y. 


r 

LOR: Low-order result 






Indicator: Exponent overflow. 


of operation. Sign 






Formatting: Equalization, 


bit = 0. Exponent = 






post- normalization. 


high-order exponent 








minus 35. 


Accumulator to FAA/XY, 11 


06 


Twos complement of (Y) is 


AAR: Ap 


accumulator or 




added to (X) and the result 


BAR: Bp 


SAA/XY 




is stored in Y. 


LOR: Low-order result 






Indicator: Exponent overflow. 


of operation. Sign 






Formatting: Equalization, 


bit = 0. Exponent = 






post- normalization. 


high-order exponent 








minus 35. 




+ 13 + I^Njj/4 "] cycles 



11 + [N^/4j cycles 
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Table F-1 (cont). Summary of Scientific Instructions 



FORMAT 


OCTAL 

OP 

CODE 


FUNCTION 


REGISTERS 

AFTER 

OPERATION 


TIMING^ 


FLOATING MULTIPLY 










Memory to 


FMA/A, XY. 13 


07 


(X) is multiplied by (A). The 


AAR; A -8 


Ni + 21 + [^Ni/2j + |^Nn/4J cycles 


accumulator 


or 




high-order product is stored 


BAR; Bp 






MAM/A, XY 




in Y; the low-order product 


LOR: Low-order product. 










is stored in LOR. 


Sign bit = 0. Exponent 










Indicator; Exponent overflow. 


= high-order exponent 










Formatting: Post -normalization. 


minu s 35. 




Accumulator 


to FAA/XY, 13 


06 


(X) is multiplied by (Y). The 


AAR: Ap 


19 + j^Ni/2j + j^Nn/4j cycles 


accumulator 


or 




high-order product is stored 


BAR: Bp 






MAA/XY 




in Y; the low-order product 


LOR: Low-order product. 










is stored in LOR. 


Sign bit = 0. Exponent 










Indicator: Exponent overflow. 


= high-order exponent 










Formatting; Post-normalization. 


minus 35. 




1 FLOATING DIVIDE 










Memory to 


FMA/A, XY, 12 


07 


(A) is divided by (X). The 


AAR; A-8 


Nj + 40 + j^Nj^/4 j cycles 


accumulator 


or 




quotient is stored in Y; the re- 


BAR; Bp 






DMA/A, XY 




mainder is stored in LOR. 


LOR; Remainder. 










Indicators: Exponent overflow. 


Sign = sign of divi- 










divide check. 


dend. Exponent = 










Formatting: Pre-normalization 


exponent of dividend 










(divisor), post-normalization 


minus 35, and plus 










quotient). 


one if the absolute 












value of the dividend 












mantissa is greater 












than the absolute 












value of the mantissa 












of the normalized 












divisor. 




Accumulator 


to FAA/XY, 12 


06 


(Y) is divided by (X). The 


AAR; Ap 


38 + r Nj^/ 4 1 cycles 


accumulator 


or 




quotient is stored in Y; the re- 


BAR; Bp 






DAA/XY 




mainder is stored in LOR. 


LOR: Remainder. 










Indicators: Exponent overflow. 


Sign = sign of divi- 










divide check. 


dend. Exponent = 










Formatting: Pre -normalization 


exponent of dividend 










(divisor), post-normalization 


minus 35, and plus 










(quotient) 


one if the absolute 












value of the dividend 












mantissa is greater 












than the absolute 












value of the mantissa 












of the normalized 












divisor. 
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Table F- 1 (cont). Summary of Scientific Instructions 



FORMAT 


OCTAL 

OP 

CODE 


FUNCTION 


REGISTERS 

AFTER 

OPERATION 


TIMING^ 


CONVERSION INSTRUCTIONS 




DECIMAL TO BINARY 

FMA/A, -Y, 03 
or 

DTB/A, -Y 


07 


The 11 -character signed dec- 
imal integer whose low-order 
character is A is converted 
to a 36 -bit binary integer. 

The binary integer is stored 
in the mantissa portion of Y; 
the exponent of (Y) is set to 
+35. One- or two -bit mantissa 
overflow is possible. If 
mantissa overflow occurs, 
the low-order one or two bits 
are shifted into LOR. Y then 
contains the high-order result 
of conversion, with an exponent 
of 36 or 37. Normalization only 
occurs with overflow. 


AAR; A- 11 
BAR: Bp 

LOR: Low-order result 

of conversion. 

Sign bit = 0. Ex- 
ponent = high-order 
exponent minus 35. 


Ni + 24 cycles 


BINARY TO DECIMAL 

FMA/A,X-, 06 
or 

BTD/A,X- 


07 


The mantissa portion of (X) is 
converted from a binary integer 
to a signed decimal integer. 

The decimal integer is stored in 
the 11 -character main memory 
field whose low-order character 
is location A. The exponent 
portion of (X) is ignored and un- 
altered. 


AAR; A- 11 
BAR: Bp 


N^ + 23 cycles 
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Table F-1 (cont). Summary of Scientific Instructions 





FORMAT 


OCTAL 

OP 

CODE 


FUNC TION 


REGISTERS 

AFTER 

OPERATION 


TIMING^ 






CONTROL INSTRUCTIONS 






FLOATING TEST AND BRANCH ON 
ACCUMULATOR CONDITION 












FMA/A,XC,04 

or 

FBA/A,XC 


07 


The mantissa portion of (X) 
is tested for the condition 
specified by C, the low- 
order octal digit of variant 1. 

C=0 no branch 
C = 1 (X) = 0 
C=2 (X) < 0 
C=3 (X) < 0 
C=4 (X) > 0 
C=5 (X) > 0 
C=6 (X) 0 

C=7 unconditional branch 


AAR: A 

BAR: B NO BRANCH 

NXT BRANCH 
SR: NXT NO BRANCH 

JI(A) BRANCH 


Ni + 4 cycles 
NO BRANCH 
Ni + 6 cycles 
BRANCH 


F-8 






If the condition specified by 
C is satisfied, program con- 
trol branches to location A. 
NOTE: (X) must be normalized. 








FLOATING TEST AND BRANCH 
ON INDICATOR 

FMA/A, OD, 05 
or 

FBI/A,0D 


07 


The indicators specified by D, 
the low- order octal digit of 
variant 1, are tested. If any 
of the indicators is set, con- 
trol branches to location A. 

D=0 no branch 
D=1 Multiply overflow 
D=2 Exponent overflow 
D=3 Exponent or multiply overflow 
D=4 Divide check 
D=5 Divide check or multiply 
overflow 

D=6 Divide check or exponent 
overflow 

D=7 Divide check, exponent 
overflow, or multiply 
overflow. 

NOTE: All indicators tested are reset. 


AAR: A 

BAR: NXT BRANCH 
Bp NO BRANCH 
SR: NXT NO BRANCH 

JI(A) BRANCH 


N: + 4 cycles 
BRANCH 
Ni + 2 cycles 
NO BRANCH 
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Table F- 1 (cont). Summary of Scientific Instructions 



FORMAT 


OCTAL 

OP 

CODE 


FUNCTION 


REGISTERS 

AFTER 

OPERATION 


TIMING^ 


BINARY MANTISSA SHIFT 


04 


If single -precision, the 
mantissa of (X) is shifted 
in the mode specified by M, 
the low-order octal digit 
of the first variant- If 
double -precision, the man- 
tissas of (X) and (LOR) are 
shifted. The second vari- 
ant V (0^V:^63) specifies 
the number of positions by 
which bits are shifted. 

M=0 left, SP, rotate (end 
around) 

M=1 left, SP, arithmetic 
M=Z left, DP, rotate 
M=3 left, DP, arithmetic 
M=4 right, SP, rotate 
M=5 right, SP, arithmetic 
M=6 right, DP, rotate 
M=7 right, DP, arithmetic 
NOTE: The exponents of (X) 
and (LOR) are set to 
zero. In an arith- 
metic shift, the signs 
of the mantissas of (X) 
and (LOR) are pre- 
served. 


AAR: Ap 
BAR: Bp 


9 + [Ng/4j cycles 


BMS/XM, V 




BINARY INTEGER ARITHMETIC INSTRUCTION 


- 


BINARY INTEGER MULTIPLY 
BIM/A,B 


05 


The four -character fields in 
memory whose low-order charac - 
ters are A and B are treated as 
Z4-bit binary integers. The in- 
tegers are multiplied together; 
the product is stored in the field 
specified by the B address. 
Indicator: Multiply overflow. 


AAR: A-4 
BAR: B-4 
LOR; unspecified 


Nj + ZO + j^N j / Z j cycles 



All timings pertain to Model ZZOO only. 
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COMPUTER-GENERATED INDEX 



A-ADDRESS REGISTER (AAR), 4-4 
A-FIELD WORD MARK 

LOAD CHARACTERS TO A-FIELD WORD MARK 



LCA, 8-63 



AAR 

A-ADDRESS REGISTER (AAR), 4-4 
ABSOLUTE, 5-9 

" MEMORY ADDRESSES, 

CONVERSION OF SYMBOLIC TAGS TO ABSOLUTE MEMORY 
ADDRESSES, 3-2 

ACCESS DRUM 

C3 CODING FOR TYPE 270 RANDOM ACCESS DRUM, 8-115 
" FILE, 

RANDOM ACCESS DRUM FILE, 1-9 
ACTIVE ADDRESS BITS IN SERIES 200 PROCESSORS, 4-14 
ACTIVITIES 

CONTROL UNIT ACTIVITIES, 2-8 

IMPUT/OUTPUT traffic CONTROL ACTIVITIES, 2-9 



ADD 

" — A, 8-16 

BINARY ADD — BA, 8-20 
complement add, 8-9 

" examples, 

COMPLEMENT ADD EXAMPLES, 8-10 
TRUE ADD EXAMPLES, 8-9 
HALF ADD — HA, 8-35 
" INSTRUCTION, 

EXTRACTION OF DATA FIELDS IN TYPICAL ADD 
INSTRUCTION, 4-2 
TYPICAL ADD INSTRUCTION, 4-1 
SERIES 200 ADD AND SUBTRACT OPERATIONS, 8-6 
TRUE ADD, 8-9 
ZERC AND ADD -- ZA, 8-23 
ADDITION 

BINARY ADDITION, 8-6 
DECIMAL addition, 8-9 

algebraic signs in DECIMAL ADDITION, 8-9 
" TABLE, 

BINARY ADDITION TABLE, 8-6 



ADDITIONAL 

" CODING RULES, 5-9 

" INPUT/OUTPUT trunks AND READ/WRITE CHANNELS, 1-17 
ADDRESS 

A AND B ADDRESSES, 3-2 



absolute memory ADDRESSES, 
CONVERSION OF SYMBOLIC 
ADDRESSES, 3-2 



TAGS TO ABSOLUTE MEMORY 



•' ASSEMBLY, 

THREE-CHARACTER ADDRESS ASSEMBLY, 5-3 
TWO-CHARACTER ADDRESS ASSEMBLY, 5-3 



ACTIVE ADDRESS BITS IN SERIES 200 PROCESSORS, 
4-14 

" CODES, 5-9 

DEFINE SYMBOLIC ADDRESS — DSA, 6-6 
INDEX REGISTER ADDRESSES IN FOUR-CHARACTER 
ADDRESSING MODE, 4-13 

INDEX REGISTER ADDRESSES IN THREE-CHARACTER 
addressing mode, 4-11 
INDEXED ADDRESS, 

ASSEMBLY OF INDEXED ADDRESS IN FOuR-CHARACTER 
ADDRESSING MODE, 5-18 

assembly of INDEXED ADDRESS IN THREE-CHARACTER 
ADDRESSING MODE, 5-17 

EXTRACTION OF INDEXED ADDRESS IN THREE-CHARACTER 
MODE, 4-12 

INDEXED FOUR-CHARACTER ADDRESSES, 

extraction OF INDIRECT AND INDEXED 

four-character ADDRESSES, 4-15 
INDIRECT ADDRESS, 

ASSEMBLY OF INDIRECT ADDRESS IN FOUR-CHARACTER 
ADDRESSING MODE, 5-19 

ASSEMBLY OF INDIRECT ADDRESS IN THREE-CHARACTER 
ADDRESSING MODE, 5-18 
" LITERALS, 5-15 



•' MODE, 

SET ADDRESS MODE — ADMODE, 7-9 
'■ MODIFICATION, 4-8 
•’ MODIFICATION CODES, 5-16 
" REGISTERS, 2-6 

THREE-CHARACTER ADDRESS, 4-9 
THREE-CHARACTER INDIRECT ADDRESS, 

EXTRACTION OF THREE-CHARACTER INDIRECT ADDRESS, 
4-10 

ADDRESSING, 4-1 

EXPLICIT ADDRESSING, IMPLICIT ADDRESSING, AND 
CHAINING, 4-14 

INDEXED ADDRESSING, 4-9, 4-13 
(CONT. ) 



ADDRESSING (CONT.) 

INDIRECT ADDRESSING, 4-9, 4-12 
" MODE, 

ADDRESSING MODES, 4-5 

ASSEMBLY OF INDEXED ADDRESS IN FOUR-CHARACTER 
ADDRESSING MODE, 5-18 

ASSEMBLY OF INDEXED ADDRESS IN THREE-CHARACTER 
ADDRESSING MODE, 5-17 

ASSEMBLY OF INDIRECT ADDRESS IN FOUR-CHARACTER 
addressing mode, 5-19 

ASSEMBLY OF INDIRECT ADDRESS IN THREE-CHARACTER 
addressing mode, 5-18 

CHANGE addressing MODE — CAM, 8-69 

CHANGING ADDRESSING MODES VIA CAM INSTRUCTION, 
8-71 

FOUR-CHARACTER ADDRESSING MODE, 4-8, 4-12 

INDEX REGISTER ADDRESSES IN FOUR-CHARACTER 
addressing mode, 4-13 

INDEX register ADDRESSES IN THREE-CHARACTER 
addressing mode, 4-11 
three-character addressing MODE, 4-6 

TWO-CHARACTER ADDRESSING MODE, 4-5 

REGISTERS USED IN ADDRESSING, 4-3 

ADMODE 

SET ADDRESS MODE — ADMODE, 7-9 
ADVANCED PROGRAMMING, 1-15 
" FEATURE, 

BCC TEST 'CONDIT IONS WITH ADVANCED PROGRAMMING 
FEATURE, 8-47 

MODEL 200 ADVANCED PROGRAMMING FEATURE, 1-16 
ALGEBRAIC SIGNS IN DECIMAL ADDITION, 8-9 
ALPHANUMERIC 

" constants, 6-4 
•• literals, 5-14 

AREA 



DEFINE AREA — DA, 6-6 
" DEFINING literals, 5-14 
RESERVE AREA — RESV, 6-5 
ARITHMETIC 

" OPERATIONS, 8-6 

automatic FORMATTING 



N ARITHMETIC OPERATIONS, 



F-2 

” SIGN CONVENTIONS, 

ARITHMETIC UNIT, 2-7 ^ _ 

DATA FLOW BETWEEN MAIN MEMORY AND ARITHMETIC 
UNIT, 2-7 

DECIMAL ARITHMETIC SIGN CONVENTIONS, 6-11 



ASSEMBLY 

" control statements, 7-1, 7-2 

" OF INDEXED ADDRESS IN FOuR-CHARACTER ADDRESSING 
MODE, 5-18 

" OF INDEXED ADDRESS IN THREE-CHARACTER ADDRESSING 
MODE, 5-17 

" OF INDIRECT ADDRESS IN FOUR-CHARACTER ADDRESSING 
MODE, 5-19 

" OF INDIRECT ADDRESS IN THREE-CHARACTER ADDRESSING 
MODE, 5-18 

" program, 

EASYCODER ASSEMBLY PROGRAM, 5-3 
RELATIONSHIP OF SOURCE, ASSEMBLY, AND OBJECT 
PROGRAMS, 5-2 

THREE-CHARACTER ADDRESS ASSEMBLY, 5-3 
two-character ADDRESS ASSEMBLY, 5-3 
AUTOMATIC FORMATTING IN ARITHMETIC OPERATIONS, F-2 
AUXILIARY READ/WRITE CHANNEL, 2-10 
B-ADDRE55 REGISTER (BAR), 4-4 
BA 

binary add — BA, 8-20 



BAR 

B-ADDRESS REGISTER (BAR), 4-4 



BASIC 

’• CONCEPTS, 4-1 

w INPUT/OUTPUT DATA PATH, 1-13 
" TEST CONDITIONS FOR BCC INSTRUCTION, 8-46 

BBE 

BRANCH ON BIT EQUAL — BBE, 8-51 

BCC 

BRANCH ON CHARACTER CONDITION -- BCC, 8-45 
BRANCH ON CHARACTER CONDITION (BCC) CONDITIONS, B-5 
" INSTRUCTION, 

BASIC TEST CONDITIONS FOR BCC INSTRUCTION, 8-46 
" TEST CONDITIONS WITH ADVANCED PROGRAMMING FEATURE, 
8-47 

BCE 

BRANCH IF CHARACTER EQUAL -- BCE, 8-49 

BCT 

BRANCH ON CONDITION TEST — BCT, 8-41 
(CONT.) 




COMPUTER-GENERATED INDEX 



BCT (CONT.) 

BRANCH ON condition TEST (BCT) INDICATOR CONDITIONS, 
B-4 

BRANCH ON CONDITION TEST (BCT) SENSE SWITCH 
CONDITIONS, B-3 
" INSTRUCTION, 

INDICATOR TEST CONDITIONS FOR BCT INSTRUCTION, 
0-43 

SENSE SWITCH CONDITIONS FOR BCT INSTRUCTION, 

8-42 

BINARY 

•' OCTAL, AND DECIMAL EQUIVALENTS, B-7 
" ADD — BA, 6-20 
" ADDITION, 6-6 
" ADDITION TABLE, 0-6 
" CONSTANTS, 6-3 
" LITERALS, 5-13 
" OCTAL equivalents, A-1 
" SUBTRACT — BS, 6-21 
’’ SUBTRACTION, 8-6 
BIT equal 

BRANCH ON BIT EQUAL — BBE, 8-51 

BITS 

ACTIVE ADDRESS BITS IN SERIES 200 PROCESSORS, 4-14 
BLANK, 5-11 

'• CONSTANTS, 6-4 
BOUNDARIES 

LEFTMOST BOUNDARIES OF PROTECTED MEMORY, 0-85 

BRANCH 

" — B, 8-40 

" IF CHARACTER EQUAL — BCE, 8-49 

•' ON BIT EQUAL -- BBE, 8-51 

" ON CHARACTER CONDITION — BCC, 8-45 

■' ON CHARACTER CONDITION (BCC) CONDITIONS, B-5 

" ON CONDITION TEST — BCT, 8-41 

" ON CONDITION TEST (BCT) INDICATOR CONDITIONS, B-4 
'■ ON CONDITION TEST (BCT) SENSE SWITCH CONDITIONS, B-3 
PERIPHERAL CONTROL AND BRANCH — PCB, 8-117, 8-133 
BS 

BINARY SUBTRACT --BS, 8-21 

CALL 

MONITOR CALL -- MC, 8-95 

CAM 

change ADDRESSING MODE — CAM, 8-69 
•' INSTRUCTION, 

CHANGING ADDRESSING MODES VIA CAM INSTRUCTION, 
8-71 

MODES SPECIFIED BY VARIANT CHARACTER IN CAM 
INSTRUCTION, 8-69 

CARD 

'■ CODES, 

PUNCHED CARD CODES, 3-9 
'■ COLUMN, 

MARK (CARD COLUMN 7), 5-5 
TYPE (CARD COLUMN 6), 5-5 
" COLUMNS 1-5, 

CARD NUMBER (CARD COLUMNS 1-5), 5-4 
" COLUMNS 15-20, 

OPERATION CODE (CARD COLUMNS 15-20), 5-7 
" COLUMNS 21-62, 

operands (CARD COLUMNS 21-62), 5-8 
" COLUMNS 8-14, 

LOCATION (CARD COLUMNS 8-14), 5-6 
'■ EQUIPMENT, 

PUNCHED CARD EQUIPMENT, 1-7 
SERIES 200 PUNCHED CARD EQUIPMENT, 1-7 
" format, 

PUNCHED CARD FORMAT, 3-8 
’’ NUMBER (CARD COLUMNS 1-5), 5-4 
" READ OPERATION, 

DATA path during CARD READ OPERATION, 1-14 
CENTRAL PROCESSOR, 1-1, 2-1 

" characteristics, 

SUMMARY OF CENTRAL PROCESSOR CHARACTERISTICS, 

2-12 

LOGICAL DIVISION OF SERIES 200 CENTRAL PROCESSOR, 

2-1 

CEQU 

CONTROL EQUALS -- CEQU, 7-11 
CHAINING 

EXPLICIT ADDRESSING, IMPLICIT ADDRESSING, AND 
CHAINING, 4-14 

CHANGE 

" ADDRESSING MODE — CAM, 8-69 
" SEQUENCE REGISTER (CSR), 4-3 
" SEQUENCING MODE — CSM, 8-72 
CHANGING ADDRESSING MODES VIA CAM INSTRUCTION, 8-71 
CHANNEL (CONT.) 



CHANNEL 

AUXILIARY READ/WRITE CHANNEL, 2-10 
READ/WRITE CHANNEL, 1-13 
READ/WRITE CHANNELS, 

ADDITIONAL INPUT/OUTPUT TRUNKS AND READ/WRITE 
CHANNELS, 1-17 

CHARACTER 
" CODES, 

SERIES 200 CHARACTER CODES, B-7 
" CONDITION, 

BRANCH ON CHARACTER CONDITION -- BCC, 6-45 
BRANCH ON CHARACTER CONDITION (BCC) CONDITIONS, 
B-5 

" EQUAL, 

branch if CHARACTER EQUAL — BCE, 6-49 
INPUT/OUTPUT CONTROL CHARACTERS, 5-16 
LOAD CHARACTERS TO A-FIELD WORD MARK — LCA, 0-63 
MOVE CHARACTERS AND EDIT -- MCE, 8-102 
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